Pagini recente » Cod sursa (job #3169359) | Cod sursa (job #2158311) | Cod sursa (job #3001863) | Cod sursa (job #1500343) | Cod sursa (job #3142401)
#include <iostream>
#include <fstream>
#include <string>
using namespace std;
ifstream fin ("evaluare.in");
ofstream fout ("evaluare.out");
int i;
char e[100000];
int a;
int expresie();
int termen();
int factor();
int nr();
int nr()
{
int r=0;
while(isalnum(e[i]) && !isalpha(e[i]))
{
r=r*10+e[i]-'0';
i++;
}
if(isalpha(e[i]))
r=a;
return r;
}
int expresie()
{
int r=termen();
while(e[i]=='+' || e[i]=='-')
{
if(e[i]=='+')
{
i++;
r+=termen();
}
else
{
i++;
r-=termen();
}
}
return r;
}
int factor()
{
int r;
if(e[i]=='(')
{
i++;
r=expresie();
i++;
}
else
r=nr();
return r;
}
int termen()
{
int r=factor();
while(e[i]=='*' || e[i]=='/')
{
if(e[i]=='*')
{
i++;
r*=termen();
}
else
{
i++;
r/=termen();
}
}
return r;
}
int main()
{
fin.getline(e,100000);
///int a;
///fin>>a;
fout<<expresie();
return 0;
}