Cod sursa(job #1988115)

Utilizator MaligMamaliga cu smantana Malig Data 2 iunie 2017 08:45:02
Problema Evaluarea unei expresii Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.15 kb
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <vector>
#include <cstring>

using namespace std;
ifstream in("evaluare.in");
ofstream out("evaluare.out");

#define ll long long
#define pb push_back
const int NMax = 2e6 + 5;
const ll inf = 1e9 + 5;


int N;
char str[NMax], *p = str;

int eval();
int termen();
int factor();

int main() {
    in>>(str);

    out<<eval()<<'\n';

    in.close();out.close();
    return 0;
}

int eval() {
    int ans = termen();
    while (*p == '+' || *p == '-') {
        switch(*p++) {
        case '+': ans += termen(); break;
        case '-': ans -= termen(); break;
        }
    }
    return ans;
}

int termen() {
    int ans = factor();
    while (*p == '*' || *p == '/') {
        switch(*p++) {
        case '*': ans *= factor(); break;
        case '/': ans /= factor(); break;
        }
    }
    return ans;
}

int factor() {
    int ans = 0;
    if (*p == '(') {
        ++p;
        ans = eval();
        ++p;
    }
    else {
        while ('0' <= *p && *p <= '9') {
            ans = ans * 10 + *p++ - '0';
        }
    }

    return ans;
}