eolymp
bolt
Try our new interface for solving problems
Problems

Ternary logic

Ternary logic

Говорят, что на заре зарождения программирования супруги программистов, не являющиеся программистами (представьте себе - такое тоже иногда имеет место), указывали своим супругам на оторванность от жизни строго двоичной логики. Представьте себе, что критике подвергался даже всем известный оператор ветвления в том или ином виде реализации практически во всех программистских инструментальных средствах. Скажу по секрету, что известен проект расширенного оператора \textbf{ЕСЛИ ТО ИНАЧЕ НО !?} - с непременным использованием двойного символа "\textbf{!?}" в качестве его признака завершения. Говорят, что именно это обстоятельство стимулировало развитие различных видов недвоичной логики, а также появление различных вариантов оператора выбора (переключения)... Пока еще нет официального статистического отчета о том, как повлияли сии новации на внутрисемейный климат семей, в которых только один из супругов является программистом, но вывод о чрезвычайной важности роли супругов программистов в процессе развития программирования можно сделать однозначно. Пусть дано выражение, составленное из чисел \textbf{0}, \textbf{1}, \textbf{2}, переменных, которые могут получить только одно из этих значений (\textbf{0}, \textbf{1}, \textbf{2}) а также операций сравнения, логического умножения, отрицания и "строгого" логического сложения (аналоги исключающего или), определенных в соответствии со следующими таблицами: Будем считать, также определенными операции "\textbf{>}" "\textbf{>=}" "\textbf{<>}" в соответствии со следующими определениями. Для любых двух \textbf{x}, \textbf{y}, значения которых \textbf{0}, \textbf{1} либо \textbf{2}: \begin{itemize} \item \textbf{x>y} равносильно \textbf{!(x} \item \textbf{x>=y} равносильно \textbf{(x>y)|(x=y)} \item \textbf{x<>y} равносильно \textbf{!(x=y)} \end{itemize} Приоритеты операций приведены ниже в порядке убывания: \textbf{!} \textbf{< > <= >=} \textbf{= <>} \textbf{&} \textbf{^} \textbf{|} В выражении могут быть использованы круглые скобки. Для заданного выражения и (при необходимости) входящих в него переменных, определить значение этого выражения. \InputFile Первая строка содержит одно число, количество тестовых примеров, которое не превосходит \textbf{1000} и не меньше \textbf{1}. Дальше идет соответствующее количество тестовых примеров. Каждый тестовый пример начинается со строки, содержащей исходное выражение. За строкой, содержащей выражение, следует последовательность из не менее одной строки, каждая из которых содержит по \textbf{3} числа, записанных через пробел - соответственно, значения \textbf{x}, \textbf{y}, \textbf{z}. Признаком конца этой последовательности строк будет строка с единственным числом, равным \textbf{3}. Выражение не содержит пробелов и может содержать не более трех односимвольных переменных. В качестве переменных могут быть использованы только '\textbf{x}', '\textbf{y}', '\textbf{z}'. Длина каждого выражения не превосходит \textbf{100}. \OutputFile Выходной файл содержит значения выражений, приведенных в отдельных строках в последовательности, соответствующей, приведенной во входном файле.
Time limit 1 second
Memory limit 256 MiB
Input example #1
2
2&1|1<=1^(2|1)
1 1 1
3
x&z|x<=z^(x|1)
2 1 1
0 0 1
3
Output example #1
1
2
0
Author T. Zarkua
Source Winter charges in Kharkov 2010 Day 7