Pagini recente » Cod sursa (job #1803320) | Cod sursa (job #737774) | Cod sursa (job #1506865) | Cod sursa (job #660904) | Cod sursa (job #623144)
Cod sursa(job #623144)
#include<fstream>
using namespace std;
ifstream in("evaluare.in");
ofstream out("evaluare.out");
char s[100005], *p=s;
int termen();
int factor();
int expresie()
{
int sum=termen();
while(*p=='+' || *p=='-')
{
if(*p=='+')
{
++p;
sum+=termen();
}
else
{
++p;
sum-=termen();
}
}
return sum;
}
int termen()
{
int sum=factor();
while(*p=='*' || *p=='/')
{
if(*p=='*')
{
++p;
sum*=factor();
}
else
{
++p;
sum/=factor();
}
}
return sum;
}
int factor()
{
int val=0;
if(*p=='(')
{
++p;
val=expresie();
++p;
}
else
{
while (*p>='0' && *p<='9')
{
val=val*10+(*p-'0');
++p;
}
}
return val;
}
int main()
{
in>>s;
out<<expresie();
}