Pagini recente » Cod sursa (job #583067) | Cod sursa (job #2165312) | Cod sursa (job #30351) | Cod sursa (job #1652246) | Cod sursa (job #1409343)
#include<algorithm>
#include<bitset>
#include<cmath>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<ctime>
#include<deque>
#include<fstream>
#include<iomanip>
#include<iostream>
#include<map>
#include<queue>
#include<set>
#include<stack>
#include<unordered_map>
#include<unordered_set>
#include<utility>
#include<vector>
using namespace std;
#ifdef HOME
const string inputFile = "input.txt";
const string outputFile = "output.txt";
#else
const string problemName = "evaluare";
const string inputFile = problemName + ".in";
const string outputFile = problemName + ".out";
#endif
const int NMAX = 100000 + 5;
char S[NMAX], *p;
int eval(), term(), fact(), numb();
int eval() {
int ans = term();
while(*p == '+' || *p == '-') {
if(*p == '+') {
p++;
ans += term();
} else {
p++;
ans -= term();
}
}
return ans;
}
int term() {
int ans = fact();
while(*p == '*' || *p == '/') {
if(*p == '*') {
p++;
ans *= fact();
} else {
p++;
ans /= fact();
}
}
return ans;
}
int fact() {
int ans;
if(*p == '(') {
p++;
ans = eval();
p++;
} else
ans = numb();
return ans;
}
int numb() {
int ans = 0;
while(*p >= '0' && *p <= '9') {
ans = ans * 10 + *p - '0';
p++;
}
return ans;
}
int main() {
#ifndef ONLINE_JUDGE
freopen(inputFile.c_str(), "r", stdin);
freopen(outputFile.c_str(), "w", stdout);
#endif
scanf("%s", S);
p = S;
printf("%d\n", eval());
return 0;
}