Pagini recente » Cod sursa (job #2865986) | Cod sursa (job #1691717)
#include<fstream>
#define DIM 100000
using namespace std;
ifstream fin("evaluare.in");
ofstream fout("evaluare.out");
int i = 0;
char s[ DIM + 5 ];
int expresie();
int termen();
int factor();
int expresie(){
int r = termen();
while( s[i] == '+' || s[i] == '-' ){
if( s[i] == '+' ){
i++;
r += termen();
}
if( s[i] == '-' ){
i++;
r -= termen();
}
}
return r;
}
int termen(){
int r = factor();
while( s[i] == '*' || s[i] == '/' ){
if( s[i] == '*' ){
i++;
r *= factor();
}
if( s[i] == '/' ){
i++;
r /= factor();
}
}
return r;
}
int factor(){
int r = 0;
if( s[i] == '(' ){
i++;
r = expresie();
i++;
}else{
while( '0' <= s[i] && s[i] <= '9' ){
r = r * 10 + ( s[i] - '0' );
i++;
}
}
return r;
}
int main(){
fin >> s;
i = 0;
fout << expresie();
return 0;
}