Pagini recente » Cod sursa (job #3169160) | Borderou de evaluare (job #158981) | Cod sursa (job #2651613) | Cod sursa (job #2599911) | Cod sursa (job #1864898)
#include <cstdio>
using namespace std;
char s[100010];
int i;
int expresie(),termen(),fact();
int expresie() {
int r=termen();
while (s[i]=='+' || s[i]=='-'){
if (s[i]=='+'){
i++;
r+=termen();
}
else {
i++;
r-=termen();
}
}
return r;
}
int termen () {
int r=fact();
while (s[i]=='*' || s[i]=='/'){
if (s[i]=='*'){
i++;
r*=fact();
}
else {
i++;
r/=fact();
}
}
return r;
}
int fact (){
int r=0;
if (s[i]=='('){
i++;
r=expresie();
i++;
}
else while (s[i]>='0' && s[i]<='9'){
r=r*10+s[i]-'0';
i++;
}
return r;
}
int main()
{
FILE *fin=fopen ("evaluare.in","r");
FILE *fout=fopen ("evaluare.out","w");
fgets(s,100010,fin);
i=0;
fprintf (fout,"%d",expresie());
return 0;
}