Pagini recente » Cod sursa (job #1989644) | Cod sursa (job #2807734) | Cod sursa (job #1853486) | Cod sursa (job #1456343) | Cod sursa (job #289674)
Cod sursa(job #289674)
#include <stdio.h>
#define dim 100010
char s[dim], *p=s;
long long termen();
long long factor();
long long eval()
{
long long r=termen();
while (*p=='+' || *p=='-')
{
if (*p=='+')
{
p++;
r+=termen();
}
else if (*p=='-')
{
p++;
r+=termen();
}
}
return r;
}
long long termen()
{
long long r=factor();
while (*p=='*' || *p=='/')
{
if (*p=='*')
{
p++;
r*=factor();
}
else if (*p=='/')
{
p++;
r/=factor();
}
}
return r;
}
long long factor()
{
long long r=0;
if (*p=='(')
{
p++;
r=eval();
p++;
}
else
while (*p>='0' && *p<='9')
{
r=r*10+*p-'0';
p++;
}
return r;
}
int main()
{
freopen("evaluare.in", "r", stdin);
freopen("evaluare.out", "w", stdout);
scanf("%s\n", s);
printf("%lld\n", eval());
return 0;
}