Pagini recente » Cod sursa (job #170093) | Cod sursa (job #1853947) | Cod sursa (job #1447835) | Cod sursa (job #225951) | Cod sursa (job #274681)
Cod sursa(job #274681)
#include <stdio.h>
char s[100100];
int n;
int p;
int unu();
int doi();
int trei();
int unu()
{
int aux=0;
if (s[p]=='(')
{
p++;
aux=doi();
p++;
return aux;
}
while(s[p]>='0' && s[p]<='9')
{
aux=aux*10+s[p]-'0';
p++;
}
return aux;
}
int doi()
{
int aux=trei();
while(s[p]=='+' || s[p]=='-')
{
if (s[p]=='+')
{
p++;
aux+=trei();
}
else
if (s[p]=='-')
{
p++;
aux-=trei();
}
}
return aux;
}
int trei()
{
int aux=unu();
while(s[p]=='*' || s[p]=='/')
{
if (s[p]=='*')
{
p++;
aux*=unu();
}
else
if (s[p]=='/')
{
p++;
aux/=unu();
}
}
return aux;
}
int main()
{
freopen("evaluare.in","r",stdin);
freopen("evaluare.out","w",stdout);
scanf("%s", &s);
printf("%d", doi());
return 0;
}