Pagini recente » Cod sursa (job #2068758) | Cod sursa (job #2493347) | Cod sursa (job #2394167) | Cod sursa (job #753306) | Cod sursa (job #2501733)
#include <iostream>
using namespace std;
int i=0;
char s[255]="(1+1)*13+10/2";
int solve();
int mult();
int num()
{
int t=0;
if(s[i]=='(') {
i++;
t=solve();
i++;
} else {
while(s[i]>='0'&&s[i]<='9')t=t*10+s[i++]-'0';
}
return t;
}
int solve()
{ int t=mult();
while(s[i]=='+' || s[i]=='-')
{
if(s[i]=='+')
{
i++;
t+=mult();
}
else
{
i++;
t-=mult();
}
}
return t;
}
int mult()
{
int t=num();
while(s[i]=='*' || s[i]=='/')
{
if(s[i]=='*')
{
i++;
t*=num();
}
else
{
i++;
t/=num();
}
}
return t;
}
int main()
{
cout<<solve();
return 0;
}