Pagini recente » Cod sursa (job #1190137) | Cod sursa (job #2908663) | Cod sursa (job #810797) | Cod sursa (job #1820889) | Cod sursa (job #846488)
Cod sursa(job #846488)
#include<fstream>
using namespace std;
ifstream f("evaluare.in");
ofstream g("evaluare.out");
int expresie();
int termen();
int factor();
int i;
char s[100100];
int expresie()
{
int sol;
sol=termen();
while(s[i]=='+'||s[i]=='-')
{
if(s[i]=='+')
{
i++;
sol+=termen();
}
else
{
i++;
sol-=termen();
}
}
return sol;
}
int termen()
{
int sol;
sol=factor();
while(s[i]=='*'||s[i]=='/')
{
if(s[i]=='*')
{
i++;
sol*=factor();
}
else
{
i++;
sol/=factor();
}
}
return sol;
}
int factor()
{
int sol=0;
if(s[i]=='(')
{
i++;
sol=expresie();
i++;
}
else
{
while(s[i]>='0'&&s[i]<='9')
{
sol=sol*10+s[i]-'0';
i++;
}
}
return sol;
}
int main()
{
f>>s+1;
i=1;
g<<expresie()<<"\n";
return 0;
}