Pagini recente » Cod sursa (job #1854803) | Cod sursa (job #2563809) | Cod sursa (job #3170259) | Cod sursa (job #1808771) | Cod sursa (job #2000526)
#include <fstream>
using namespace std;
ifstream fin("evaluare.in");
ofstream fout("evaluare.out");
char v[100005];
int nr;
int eval();
int termen()
{
int r=0;
if(v[nr]=='(')
{
nr++;
r=eval();
nr++;
}
while(v[nr]>='0'&&v[nr]<='9')
{
r=r*10+v[nr]-'0';
nr++;
}
return r;
}
int factor()
{
int r=termen();
while(v[nr]=='*' || v[nr]=='/')
{
if(v[nr]=='*') nr++,r*=factor();
if(v[nr]=='/') nr++,r/=factor();
}
return r;
}
int eval()
{
int r=factor();
while(v[nr]=='+' || v[nr]=='-')
{
if(v[nr]=='+') nr++,r+=factor();
if(v[nr]=='-') nr++,r-=factor();
}
return r;
}
int main()
{
fin>>v;
fout<<eval();
}