Pagini recente » Cod sursa (job #2872510) | Cod sursa (job #2536904) | Cod sursa (job #2809089) | Cod sursa (job #287458) | Cod sursa (job #790245)
Cod sursa(job #790245)
#include<fstream>
using namespace std;
ifstream f("evaluare.in");
ofstream g("evaluare.out");
char s[100001];
int i=0;
float eval();
float termen();
float factor();
float eval ()
{
float r=termen();
while(s[i]=='+' || s[i]=='-')
{
if(s[i]=='+')
{
i++;
r+=termen();
}
else if(s[i]=='-')
{
i++;
r-=termen();
}
}
return r;
}
float termen ()
{
float r=factor();
while(s[i]=='*' || s[i]=='/')
{
if(s[i]=='*')
{
i++;
r*=factor();
}
else if(s[i]=='/')
{
i++;
r/=factor();
}
}
return r;
}
float factor ()
{
float r=0;
if(s[i]=='(')
{
i++;
r=eval();
i++;
}
while(s[i]>='0' && s[i]<='9')
{
r=r*10+float(s[i]-'0');
i++;
}
return r;
}
int main ()
{
f.getline(s,100001);
g<<(long long)eval();
return 0;
}