Cod sursa(job #2283305)

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

using namespace std;

char s[100005], 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()
{
    fgets(s, 100005, fopen("evaluare.in", "r"));
	fprintf(fopen("evaluare.out", "w"), "%d\n", expr(0));
    return 0;
}