Cod sursa(job #1258139)

Utilizator LegionHagiu Stefan Legion Data 8 noiembrie 2014 15:23:53
Problema Bool Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.97 kb
#include <iostream>
#include <fstream>
#include <string>

using namespace std;

bool litere[30];
string s;

bool rezolva(int c)
{
	static int i;
	int fosttermen=-1, curenttermen=0;
	int negari=0;
	int armura = 0;
	for (i = c; i < s.length(); i++)
	{
		if (s[i] == '(')
		{
			if (curenttermen == 0&&armura==0)
			{
				if (negari % 2 == 0)
				{
					curenttermen = rezolva(i + 1);
				}
				else
				{
					curenttermen = !rezolva(i + 1);
				}
				negari = 0;
			}
		    
			else rezolva(i + 1);
		}
		if (s[i] == 'T'&&s[i + 1] == 'R'){
			i += 4; 
			if (armura == 0){
				if (negari % 2 == 0)
				{
					curenttermen = 1;
				}
				else
				{
					curenttermen = 0;
				}
				negari = 0;
			}
		}
		if (s[i] == 'F'&&s[i + 1] == 'A'){
			i += 5;
			if (armura == 0){
				if (negari % 2 == 0)
				{
					curenttermen = 0;
				}
				else
				{
					curenttermen = 1;
				}
				negari = 0;
			}
			}
		if (s[i] == 'N'&&s[i + 1] == 'O'){ i += 3; negari++; }
		if (s[i] == 'A'&&s[i + 1] == 'N')
		{
			fosttermen = curenttermen;
			curenttermen = 0;
			i += 3;
			armura = 0;
		}
		if (s[i] == 'O'&&s[i + 1] == 'R')
		{
			i += 2;
			if (curenttermen == 1){ armura = 1; }
		}
		if (s[i] >= 'A'&&s[i] <= 'Z' && (s[i + 1] == ' ' || s[i + 1] == ')'))
		{
			if (curenttermen == 0&&armura==0)
			{
				if (negari % 2 == 0)
				{
					curenttermen = litere[s[i] - 64];
				}
				else { curenttermen = !litere[s[i] - 64]; }
				negari = 0;

			}
		}
		if (s[i] == ')'){ i++; break; }
	}
	if (fosttermen == -1)
	{
		if (curenttermen == 1){ return true; }
		else { return false; }
	}
	if (fosttermen >= 0)
	{
		if (curenttermen == 1 && fosttermen == 1){ return true; }
		else { return false; }
	}
}

int main()
{
	ifstream in("bool.in");
	ofstream out("bool.out");
	int i, n;
	char c;
	getline(in, s);
	in >> n;
	for (i = 1; i <= n; i++)
	{
		in >> c;
		litere[c - 64] = !litere[c - 64];
		out << rezolva(0);
	}
}