Pagini recente » Cod sursa (job #2429803) | Cod sursa (job #3151315) | Cod sursa (job #1664173) | Cod sursa (job #3157032) | Cod sursa (job #1331310)
#include<fstream>
using namespace std;
int i;
char ch[100003];
int exp();
int termen();
int factor();
int factor(){
int r;
if(ch[i]=='('){
i++;
r=exp();
i++;
}else{
r=0;
while(ch[i]>='0' && ch[i]<='9'){
r=r*10+(ch[i]-'0');
i++;
}
}
return r;
}
int termen(){
int r=factor();
while(ch[i]=='*' || ch[i]=='/'){
if(ch[i]=='*'){
i++;
r*=factor();
}else{
i++;
r/=factor();
}
}
return r;
}
int exp(){
int r=termen();
while(ch[i]=='+' || ch[i]=='-'){
if(ch[i]=='+'){
i++;
r+=termen();
}else{
i++;
r-=termen();
}
}
return r;
}
ifstream in("evaluare.in");
ofstream out("evaluare.out");
int main(){
in>>ch+1;
i=1;
out<<exp();
return 0;
}