Pagini recente » Cod sursa (job #1002071) | Cod sursa (job #387731) | Cod sursa (job #2211025) | Cod sursa (job #2456802) | Cod sursa (job #2109815)
#include <bits/stdc++.h>
using namespace std;
ifstream fi("evaluare.in");
ofstream fo("evaluare.out");
int p=0;
char S[100010];
int termen();
int factor();
int eval();
int termen()
{
int rez=factor();
while(S[p]=='*' || S[p]=='/')
{
if(S[p]=='*')
{
p++;
rez*=factor();
break;
}
else
if(S[p]=='/')
{
p++;
rez/=factor();
break;
}
}
return rez;
}
int factor()
{
long rez=0;
if(S[p]=='(')
{
p++;
rez=eval();
p++;
}
else
{
while(S[p]>='0' && S[p]<='9')
{
rez=rez*10+(S[p]-'0');
p++;
}
}
return rez;
}
int eval()
{
int rez=termen();
while(S[p]=='+' || S[p]=='-')
{
if(S[p]=='+')
{
p++;
rez+=termen();
break;
}
else
if(S[p]=='-')
{
p++;
rez-=termen();
break;
}
}
return rez;
}
int main()
{
fi>>S;
fo<<eval();
fi.close();
fo.close();
return 0;
}