Pagini recente » Cod sursa (job #1434883) | Cod sursa (job #2224351) | Cod sursa (job #1808135) | Cod sursa (job #1594461) | Cod sursa (job #974536)
Cod sursa(job #974536)
#include<fstream>
using namespace std;
const int MAXN=100010;
char e[MAXN],*p=e;
int lg;
void read();
int eval();
int termen();
int factor();
void write();
int main()
{
read();
write();
return 0;
}
void read()
{
ifstream fin("evaluare.in");
char c;
fin.get(c);
for(lg=1; c!='\n'; ++lg)
{
e[lg-1]=c;
fin.get(c);
}
--lg;
fin.close();
}
int eval()
{
int r=termen();
while (*p=='+' || *p=='-')
{
if (*p=='+')
{
++p;
r+=termen();
}
else if (*p=='-')
{
++p;
r-=termen();
}
}
return r;
}
int termen()
{
int r=factor();
while (*p=='*' || *p=='/')
{
if (*p=='*')
{
++p;
r*=factor();
}
else if (*p=='/')
{
++p;
r/=factor();
}
}
return r;
}
int factor()
{
int r=0;
if (*p=='(')
{
++p;
r=eval();
++p;
}
else
{
while (*p>='0' && *p<='9')
{
r=r*10+(*p-'0');
++p;
}
}
return r;
}
void write()
{
ofstream fout("evaluare.out");
fout<<eval()<<'\n';
fout.close();
}