Pagini recente » Cod sursa (job #800297) | Cod sursa (job #2539888) | Cod sursa (job #3216046)
#include <fstream>
using namespace std;
ifstream fin ("evaluare.in");
ofstream fout ("evaluare.out");
char sir[100001];
int expresie();
int termen();
int factor();
int constanta();
int i=0;
int main()
{
fin>>sir;
fout<<expresie();
return 0;
}
int expresie()
{
int x=termen();
while(sir[i]=='+'||sir[i]=='-')
{
if(sir[i]=='+')
{ i++;
x=x+termen();
}
else
{i++;
x=x-termen();
}
}
return x;
}
int termen()
{
int x=factor();
while(sir[i]=='*'||sir[i]=='/')
{
if(sir[i]=='*')
{i++;
x=x*factor();
}
else
{i++;
x=x/factor();
}
}
return x;
}
int factor()
{
int x;
if(sir[i]=='(')
{
i++;
x=expresie();
i++;
}
else
x=constanta();
return x;
}
int constanta()
{
int x=0;
while(sir[i]>='0'&& sir[i]<='9')
{
x=x*10+sir[i]-'0';
i++;
}
return x;
}