Cod sursa(job #2324495)

Utilizator AndreiVisoiuAndrei Visoiu AndreiVisoiu Data 20 ianuarie 2019 21:03:45
Problema Evaluarea unei expresii Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.89 kb
#include <cstdio>

using namespace std;

const int MAX = 100001;
char S[MAX], *p = S;

int termen();
int factor();

int eval() {
    int r = termen();
    while(*p == '-' || *p == '+') {
        if(*p == '-')
            ++p, r -= termen();
        else ++p, r += termen();
    }
    return r;
}


int termen() {
    int r = factor();
    while(*p == '*' || *p == '/') {
        if(*p == '*')
            ++p, r *= termen();
        else ++p, r /= termen();
    }
    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;
}

int main()
{
    freopen("evaluare.in", "r", stdin);
    freopen("evaluare.out", "w", stdout);
    gets(S);
    printf("%i", eval());
    return 0;
}