Cod sursa(job #2283301)

Utilizator Groza_Iulia_DianaGroza Iulia Diana Groza_Iulia_Diana Data 15 noiembrie 2018 12:50:51
Problema Evaluarea unei expresii Scor 40
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.81 kb
#include <bits/stdc++.h>

using namespace std;

char s[100010], pr[4][4]={"+-", "*/", "^", ""}, *p = s;

int eval(int a, int b, char c)
{
    switch(c)
    {
        case '+': return a+b;
        case '-': return a-b;
        case '*': return a*b;
        case '/': return a/b;
    }
}

int expr(int lvl)
{
    int x, y;
    if(lvl==2)
        if(*p=='(')
        {
            ++p;
            x=expr(0);
            ++p;
        }
        else for(x=0; *p>='0' && *p<='9'; p++)
            x=x*10+*p-'0';
    else
        for(x=expr(lvl+1); strchr(pr[lvl], *p); x=y)
            y = eval(x, expr(lvl+1), *p++);
    return x;
}

int main()
{
    freopen("evaluare.in", "r", stdin);
    freopen("evaluare.out", "w", stdout);
    scanf("%s", s);
    printf("%d", expr(0));
    return 0;
}