Cod sursa(job #2075851)

Utilizator LeVladzCiuperceanu Vlad LeVladz Data 25 noiembrie 2017 18:57:39
Problema Evaluarea unei expresii Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.07 kb
#include <fstream>

using namespace std;

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

int i;
char s[100001];

int expresie();
int termen();
int factor();

int main ()
{
    fin >> s;
    i = 0;
    fout << expresie();
    return 0;
}

int expresie()
{
    int r = termen();
    while (s[i] == '+' || s[i] == '-')
        if (s[i] == '+')
        {
            i++;
            r += termen();
        }
        else
        {
            i++;
            r -= termen();
        }
    return r;
}

int termen()
{
    int r = factor();
    while (s[i] == '*' || s[i] == '/')
        if (s[i] == '*')
        {
            i++;
            r *= factor();
        }
        else
        {
            i++;
            r /= factor();
        }
    return r;
}

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