Pagini recente » Cod sursa (job #176342) | Cod sursa (job #981733) | Profil Axinte_Dana_Raluca_323CA | Cod sursa (job #1424178) | Cod sursa (job #561681)
Cod sursa(job #561681)
#include <fstream>
using namespace std;
int poz=0;
char s[100002];
ifstream in("evaluare.in");
ofstream out("evaluare.out");
int expresie(),factor(),termen(),numar();
int expresie()
{
int sum=termen();
while (s[poz]=='+' || s[poz]=='-')
{
if (s[poz]=='+')
{
poz++;
sum+=termen();
}
else
{
poz++;
sum-=termen();
}
}
return sum;
}
int termen()
{
int sum=factor();
while (s[poz]=='*' || s[poz]=='/')
if (s[poz]=='*')
{
poz++;
sum*=factor();
}
else
{
poz++;
sum/=factor();
}
return sum;
}
int factor()
{
int val,semn=1;
while (s[poz]=='+' || s[poz]=='-')
if (s[poz++]=='-')
semn=-semn;
if (s[poz]=='(')
{
poz++;
val=expresie();
poz++;
return val;
}
return numar();
}
int numar()
{
int nr=0;
while (s[poz]>='0' && s[poz]<='9')
nr=nr*10+s[poz++]-'0';
return nr;
}
int main()
{
in.getline(s,100001);
out<<expresie()<<"\n";
return 0;
}