Cod sursa(job #2373611)

Utilizator AndoneAlexandruAndone Alexandru AndoneAlexandru Data 7 martie 2019 14:33:34
Problema Evaluarea unei expresii Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1 kb
#include <fstream>
#include <cstring>
using namespace std;

char s[100005];
int i = 0;

int num();
int mult();

int solve() {
    int t = mult();
    while (s[i] == '+' || s[i] == '-') {
        if (s[i] == '+') {
            i++;
            t += mult();
        }
        else {
            i++;
            t -= mult();
        }
    }
    return t;
}

int mult() {
    int t = num();
    while (s[i] == '*' || s[i] == '/') {
        if (s[i] == '*') {
            i++;
            t *= num();
        }
        else {
            i++;
            t /= num();
        }
    }
    return t;
}

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

int main() {
    ifstream f("evaluare.in");
    ofstream g("evaluare.out");
    f.getline(s, 100005);
    g << solve();
}