Pagini recente » Cod sursa (job #3031946) | Cod sursa (job #2174006) | Cod sursa (job #228360) | Cod sursa (job #923331) | Cod sursa (job #591214)
Cod sursa(job #591214)
#include <fstream>
using namespace std;
isftream in("evaluare");
ofstream out("evaluare");
int poz;
char s[1005];
int expresie();
int termen();
int factor();
int expresie()
{
int val=termen();
while(s[poz]=='+' || s[poz]=='-')
{
if(s[poz]=='+')
{
++poz;
val+=termen();
}
else
{
++poz;
val-=termen();
}
}
return val;
}
int termen()
{
int val=factor();
while(s[poz]=='*'||s[poz]=='%')
{
if(s[poz]=='*')
{
++poz;
val*=factor();
}
else
{
++poz;
val%=factor();
}
}
return val;
}
int factor()
{
int val=0,semn=1;
while(s[poz]=='-')
{
++poz;
semn=-semn;
}
if(s[poz]=='(')
{
++poz;
val=expresie();
++poz;
return val*semn;
}
while(s[poz]>='0' && s[poz]<='9')
{
val=val*10+s[poz]-'0';
poz++;
}
return val*semn;
}
int main()
{
gets(s);
int v;
v=expresie();
printf("%d\n",v);
return 0;
}