Pagini recente » Cod sursa (job #3160312) | Cod sursa (job #687793) | Cod sursa (job #2192615) | Cod sursa (job #642908) | Cod sursa (job #1309476)
#include <fstream>
#include <cstring>
using namespace std;
ifstream fin ("evaluare.in");
ofstream fout("evaluare.out");
char s[100010];
int i;
int expresie();
int termen();
int factor();
int expresie() {
int r;
r = termen();
while ( s[i] == '+' || s[i] == '-' ) {
if (s[i] == '+') {
i++;
r+=termen();
} else {
i++;
r-=termen();
}
}
return r;
}
int termen() {
int r;
r = factor();
while ( s[i] == '*' || s[i] == '/' ) {
if (s[i] == '*') {
i++;
r*=factor();
} else {
i++;
r/=factor();
}
}
return r;
}
int factor() {
int r = 0;
if (s[i] == '(') {
i++;
r = expresie();
i++;
} else {
r = 0;
while (s[i] >= '0' && s[i] <= '9') {
r = r*10 + s[i] - '0';
i++;
}
}
return r;
}
int main()
{
/*
expresie = termen1 +- termen2 +- termen3 ... +- termenn
termen = factor1 * / factor2 * / ... * / factorm
factor = (expresie)
numar
*/
fin>>s+1;
i = 1;
fout<<expresie()<<"\n";
return 0;
}