Pagini recente » Cod sursa (job #1639370) | Cod sursa (job #699080) | Cod sursa (job #1181637) | Cod sursa (job #1057442) | Cod sursa (job #2501749)
#include <iostream>
using namespace std;
char c[1001];
int i;
int solve();
int mult();
int num();
int solve()
{
int t=mult();
while(c[i]=='+' || c[i]=='-')
{
if(c[i]=='+')
{
i++;
t+=mult();
}
else
{
i++;
t-=mult();
}
}
return t;
}
int mult()
{
int t=num();
while(c[i]=='*'|| c[i]=='/')
{
if(c[i]=='*')
{
i++;
t*=num();
}
else
{
i++;
t/=num();
}
}
return t;
}
int num()
{
int t=0;
if(c[i]=='(')
{
i++;
t=solve();
i++;
}
else
while(isdigit(c[i]))
{
t=t*10+(int)c[i++]-'0';
}
return t;
}
int main()
{
cin.getline(c,1001);
cout<<solve();
return 0;
}