Pagini recente » Cod sursa (job #2594480) | Cod sursa (job #1375101) | Cod sursa (job #1133351) | Cod sursa (job #743868) | Cod sursa (job #2841806)
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("bool.in");
ofstream fout("bool.out");
char s[1010],c;
int i,n,l;
map<char,bool>f;
bool term(),fact();
bool expresie()
{
int sum=term();
while(s[i]==')' || s[i]==' ')
i++;
while(i<l && s[i]=='O' && s[i+1]=='R')
i+=3,sum=(sum | term());
return sum;
}
bool term()
{
int prod=fact();
while(s[i]==')' || s[i]==' ')
i++;
while(s[i]=='A' && s[i+1]=='N')
i+=4,prod=(prod & fact());
return prod;
}
bool fact()
{
int val=0,semn=0;
while(s[i]==')' || s[i]==' ')
i++;
while(s[i]=='N' && s[i+1]=='O')
semn=1-semn,i+=4;
if(s[i]=='(')
{
i++;
val=expresie();
while(s[i]==')' || s[i]==' ')
i++;
if(semn==0)
return val;
else return !val;
}
else if(s[i]=='T' && s[i+1]=='R')
i+=5,val=1;
else if(s[i]=='F' && s[i+1]=='A')
i+=6,val=0;
else val=f[s[i]],i+=2;
while(s[i]==')' || s[i]==' ')
i++;
if(semn==0)
return val;
else return !val;
}
int main()
{
for(i='A';i<='Z';i++)
f[(char)i]=false;
fin.getline(s,1005);
l=strlen(s);
fin>>n;
while(n--)
{
fin>>c;
f[c]=(!f[c]);
i=0;
fout<<expresie();
}
return 0;
}