Pagini recente » Cod sursa (job #2918625) | Cod sursa (job #1243026) | Cod sursa (job #1784384) | Cod sursa (job #717146) | Cod sursa (job #2546750)
#include<bits/stdc++.h>
using namespace std;
inline int expresie();
inline int termen();
inline int factor();
char s[100005];
int i;
int main()
{
freopen("evaluare.in","r",stdin);
freopen("evaluare.out","w",stdout);
scanf("%s",s+1);
int n=strlen(s+1);
i=1;
int sol=expresie();
printf("%d\n",sol);
return 0;
}
inline int expresie()
{
int r=termen();
if(s[i]=='+' || s[i]=='-')
{
if(s[i]=='+')
{
i++;
r+=termen();
}
else
{
i++;
r-=termen();
}
}
return r;
}
inline int termen()
{
int r=factor();
if(s[i]=='*' || s[i]=='/')
{
if(s[i]=='*')
{
i++;
r*=factor();
}
else
{
i++;
r/=factor();
}
}
return r;
}
inline int factor()
{
int r;
if(s[i]=='(')
{
i++;
r=expresie();
i++;
}
else
{
r=0;
while(isdigit(s[i]))
{
r=r*10+s[i]-'0';
i++;
}
}
return r;
}