Cod sursa(job #1861672)

Utilizator GinguIonutGinguIonut GinguIonut Data 29 ianuarie 2017 10:45:53
Problema Evaluarea unei expresii Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.04 kb
#include <fstream>

#define nMax 100001

using namespace std;

ifstream fin("evaluare.in");
ofstream fout("evaluare.out");

char s[nMax];
char *p=s;
int expresie();
int factor()
{
    int ans=0;
    if(*p=='(')
    {
        p++;
        ans=expresie();
        p++;
    }
    else
    {
        while(*p>='0' && *p<='9')
        {
            ans=ans*10+*p-'0';
            p++;
        }
    }
    return ans;
}

int termen()
{
    int ans=factor();

    while(*p=='*' || *p=='/')
    {
        if(*p=='*')
        {
            p++;
            ans*=factor();
        }
        else
        {
            p++;
            ans/=factor();
        }
    }

    return ans;
}

int expresie()
{
    int ans=termen();

    while(*p=='+' || *p=='-')
    {
        if(*p=='+')
        {
            p++;
            ans+=termen();
        }
        else
        {
            p++;
            ans-=termen();
        }
    }

    return ans;
}

int main()
{
    fin>>s;
    fout<<expresie();
}