Cod sursa(job #1453789)

Utilizator CollermanAndrei Amariei Collerman Data 24 iunie 2015 18:28:45
Problema Bool Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.44 kb
#include<fstream>
using namespace std;
ofstream fout("bool.out");
ifstream fin("bool.in");
const int MMAX = 1005;
const int NMAX = 105;

int n, val[30];
char exp[MMAX], yolo[NMAX], *p = exp;

int sau();
void sterge() { while( *p == ' ') p++; }

int eval()
{
    sterge();
    int sol = 0;

        if(*p == 'N' && *(p+1) == 'O') {
            p += 3;
            sol = 1 - eval();
        }
        else if(*p == '(') {
            p++;
            sol = sau();
            p++;
        }
        else if(*p == 'T' && *(p+1) == 'R') {
            sol = 1;
            p += 4;
        }
        else if(*p == 'F' && *(p+1) == 'A') {
            sol = 0;
            p += 5;
        }
        else {
            sol = val[*p - 'A' + 1];
            p++;
        }

    sterge();
    return sol;
}

int si()
{
    sterge();
    int sol = eval();

    while(*p == 'A' && *(p+1) == 'N') {
        p += 3;
        sol &= eval();
    }

    sterge();
    return sol;
}

int sau()
{
    sterge();
    int sol = si();

    while(*p == 'O' && *(p+1) == 'R') {
        p += 2;
        sol |= si();
    }
    sterge();

    return sol;
}

int main()
{
    fin.getline(exp, MMAX);
    fin >> n;
    fin >> yolo+1;

    for(int i=1; i<=n; i++) {
        val[yolo[i] - 'A' + 1] = 1 - val[yolo[i] - 'A' + 1];
        fout << sau();
        p = exp;
    }

    fin.close();
    fout.close();
    return 0;
}