Pagini recente » Cod sursa (job #1428083) | Cod sursa (job #1373814) | Cod sursa (job #1027024) | Cod sursa (job #2571799) | Cod sursa (job #2931087)
#include <fstream>
using namespace std;
ifstream fin("evaluare.in");
ofstream fout("evaluare.out");
char s[100001];
int i=0;
int expresie();
int termen();
int factor();
int constanta();
int expresie(){
int x=termen();
while(s[i]=='+' || s[i]=='-'){
if(s[i]=='+')
i++, x+=termen();
else
i++,x-=termen();
}
return x;
}
int termen(){
int x=factor();
while(s[i]=='*' || s[i]=='/'){
if(s[i]=='*')
i++,x*=factor();
else
i++,x/=factor();
}
return x;
}
int factor(){
int x;
if(s[i]=='('){
i++;/// sra peste paranteza
x=expresie();
i++; /// sar peste paranteza
}
else
x=constanta();
return x;
}
int constanta(){
int x=0;
while(s[i]<='9' && s[i]>='0'){
x=x*10+s[i]-'0';
i++;
}
return x;
}
int main(){
fin>>s;
fout<<expresie();
return 0;
}