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