Pagini recente » Cod sursa (job #471892) | Cod sursa (job #48831) | Cod sursa (job #1700832) | Istoria paginii runda/simulare_oni_hlo_mediu/clasament | Cod sursa (job #2535372)
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5;
char s[5 + N];
int p;
int expresie();
int termen();
int factor();
int expresie() {
int sum = termen();
while(s[p] == '+' || s[p] == '-') {
if(s[p] == '+') {
p++;
sum += termen();
} else {
p++;
sum -= termen();
}
}
return sum;
}
int termen(){
int prod = factor();
while(s[p] == '*' || s[p] == '/'){
if(s[p] == '*'){
p++;
prod *= factor();
} else {
p++;
prod /= factor();
}
}
return prod;
}
int factor(){
int val(0), semn(1);
while(s[p] == '-'){
semn = -semn;
p++;
}
if(s[p] == '('){
p++;
val = expresie();
p++;
return semn * val;
}
while(s[p] >= '0' && s[p] <= '9')
val = val * 10 + (s[p++] - '0');
return semn * val;
}
int main() {
freopen("evaluare.in", "r", stdin);
freopen("evaluare.out", "w", stdout);
fgets(s, 3 + N, stdin);
printf("%d\n", expresie());
return 0;
}