Pagini recente » Cod sursa (job #1818516) | Cod sursa (job #1421022) | Cod sursa (job #639362) | Cod sursa (job #1058577) | Cod sursa (job #3158563)
#include <iostream>
#include <fstream>
#define sMax 100000
using namespace std;
ifstream fin("evaluare.in");
ofstream fout("evaluare.out");
char s[sMax];
int sIdx;
int adunare();
int factor(){
int result=0;
if(s[sIdx]=='('){
sIdx++;
result=adunare();
sIdx++;
}
else{
while(s[sIdx]>='0'&&s[sIdx]<='9'){
result=result*10+s[sIdx++]-'0';
}
}
return result;
}
int inmultire(){
int result;
result=factor();
while(s[sIdx]=='*'||s[sIdx]=='/'){
if(s[sIdx++]=='*')
result*=factor();
else
result/=factor();
}
return result;
}
int adunare(){
int result;
result=inmultire();
while(s[sIdx]=='+'||s[sIdx]=='-'){
if(s[sIdx++]=='+')
result +=inmultire();
else
result -=inmultire();
}
return result;
}
int main()
{
fin>>s;
fout<<adunare();
return 0;
}