Pagini recente » Cod sursa (job #1396478) | Cod sursa (job #2577136) | Cod sursa (job #728157) | Cod sursa (job #3275389) | Cod sursa (job #2719526)
#include <bits/stdc++.h>
#define nmax 100002
using namespace std;
char s[nmax],*p=s;
int eval();
int termen();
int factor();
int eval()
{
int ans=termen();
while(*p=='+'||*p=='-')
{
if(*p=='+') {p++;ans+=termen();}
if(*p=='-') {p++;ans-=termen();}
}
return ans;
}
int termen()
{
int ans=factor();
while(*p=='*'||*p=='/')
{
if(*p=='*') {p++;ans*=factor();}
if(*p=='/') {p++;ans/=factor();}
}
return ans;
}
int factor()
{
int ans=0;
if(*p=='(')
{
p++;
ans=eval();
p++;
}
else while('0'<=*p&&*p<='9')
{
ans=ans*10+*p-'0';
p++;
}
return ans;
}
int main()
{
freopen("evaluare.in","r",stdin);
freopen("evaluare.out","w",stdout);
cin>>s;
cout<<eval();
return 0;
}