Pagini recente » Cod sursa (job #2909730) | Cod sursa (job #1634345) | Cod sursa (job #2929905) | Cod sursa (job #1354338) | Cod sursa (job #535462)
Cod sursa(job #535462)
#include<stdio.h>
int poz=0;
const int N=100001;
char s[N];
int termen();
int factor();
int expresie()
{
int sum=termen();
while(s[poz]=='+' || s[poz]=='-')
{
if(s[poz]=='+')
{
++poz;
sum+=termen();
}
else
{
++poz;
sum-=termen();
}
}
return sum;
}
int termen()
{
int p=factor();
while(s[poz]=='*' || s[poz]=='/')
{
if(s[poz]=='*')
{
++poz;
p*=factor();
}
else
{
++poz;
p/=factor();
}
}
return p;
}
int factor()
{
int val=0, semn=1;
if (s[poz]=='-')
{
++poz;
semn=-1;
}
if (s[poz]=='(')
{
++poz;
val=expresie();
++poz;
return semn*val;
}
while ( s[poz]>='0' && s[poz]<='9' )
{
val=val*10+(s[poz]-'0');
++poz;
}
return semn*val;
}
int main()
{
freopen("evaluare.in","r",stdin);
freopen("evaluare.out","w",stdout);
gets(s);
printf("%d\n",expresie());
return 0;
}