Pagini recente » Cod sursa (job #2674480) | Cod sursa (job #3272574) | Cod sursa (job #171348) | Cod sursa (job #2986720) | Cod sursa (job #3208446)
#include <bits/stdc++.h>
using namespace std;
ifstream f("evaluare.in");
ofstream g("evaluare.out");
char *p,s[100005];
int eval();
int factor();
int termen();
int eval(){
int rez;
rez=termen();
while(*p=='+' || *p=='-'){
if(*p=='+'){
p++;
rez+=termen();
}
else{
p++;
rez-=termen();
}
}
return rez;
}
int termen(){
int rez;
rez=factor();
while(*p=='*' || *p=='/'){
if(*p=='*'){
p++;
rez*=factor();
}
else{
p++;
rez/=factor();
}
}
return rez;
}
int factor(){
int rez=0;
if(*p=='('){
p++;
rez=eval();
p++;
}
else while('0'<=*p && *p<='9'){
rez=rez*10+*p-'0';
p++;}
}
int main()
{
f.getline(s, 100005);
p=s;
g<<eval();
return 0;
}