Pagini recente » Cod sursa (job #3001104) | Cod sursa (job #1193075) | Cod sursa (job #2844296) | Cod sursa (job #403677) | Cod sursa (job #591213)
Cod sursa(job #591213)
#include <fstream>
using namespace std;
int poz=0;
char s[100002];
ifstream in("evaluare.in");
ofstream out("evaluare.out");
int termen(),expresie(),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 semn*val;
}
while(s[poz]>='0' && s[poz]<='9')
{
val=val*10+s[poz]-'0';
++poz;
}
return val*semn;
}
int main()
{
in.getline(s,100005);
out<<expresie();
}