Pagini recente » Cod sursa (job #535381) | Cod sursa (job #3145021) | Cod sursa (job #2304801) | Cod sursa (job #1481108) | Cod sursa (job #3250750)
#include <bits/stdc++.h>
#define N 100005
using namespace std;
ifstream fin("evaluare.in");
ofstream fout("evaluare.out");
int expresie();
int termen();
int factor();
int n,i,j,x;
char s[N];
bool nr(int x)
{
return ('0'<=s[x] && s[x]<='9');
}
int main()
{
fin>>s;
n=strlen(s);
fout<<expresie();
return 0;
}
int expresie()
{
int x=termen();
while(i<n && (s[i]=='+' || s[i]=='-'))
{
if(s[i]=='+') x+=termen();
else if(s[i]=='-') x-=termen();
}
}
int termen()
{
int x=factor();
while(i<n && (s[i]=='*' || s[i]=='/'))
{
if(s[i]=='*') x*=factor();
else if(s[i]=='/') x/=factor();
}
}
int factor()
{
int x=0;
if(s[i]=='(')
{
i++;
x=expresie();
i++;
}
else
{
while(nr(i))
{
x=x*10+s[i]-'0';
}
}
return x;
}