小 L 今天学习了 Kleene 三值逻辑。
在三值逻辑中,一个变量的值可能为:真(
在三值逻辑上也可以定义逻辑运算。由于小 L 学习进度很慢,只掌握了逻辑非运算
现在小 L 有
,其中 为 的一种; ; 。
一开始,小 L 会给这些变量赋初值,然后按顺序运行这
小 L 希望执行了所有语句后,所有变量的最终值与初值都相等。在此前提下,小 L 希望初值中
在本题中,你需要帮助小 L 找到
输入格式
本题的测试点包含有多组测试数据。
输入的第一行包含两个整数
接下来,对于每组测试数据:
- 输入的第一行包含两个整数
和 ,分别表示变量个数和语句条数。 - 接下来
行,按运行顺序给出每条语句。- 输入的第一个字符
描述这条语句的类型。保证 为TFU+-
的其中一种。 - 若
为TFU
的某一种时,接下来给出一个整数 ,表示该语句为 ; - 若
为+
,接下来给出两个整数 ,表示该语句为 ; - 若
为-
,接下来给出两个整数 ,表示该语句为 。
- 输入的第一个字符
输出格式
对于每组测试数据输出一行一个整数,表示所有符合条件的赋初值方案中,
样例一
input
1 3 3 3 - 2 1 - 3 2 + 1 3 3 3 - 2 1 - 3 2 - 1 3 2 2 T 2 U 2
output
0 3 1
数据范围与提示
【样例解释 #1】
第一组测试数据中,
; ; 。
一组合法的赋初值方案为
第二组测试数据中,
; ; 。
唯一的赋初值方案为
第三组测试数据中,
; ;
一个最小化
【样例解释 #2】
该组样例满足测试点
【样例解释 #3】
该组样例满足测试点
【样例解释 #4】
该组样例满足测试点
【数据范围】
对于所有测试数据,保证:
, ;- 对于每个操作,
为TFU+-
中的某个字符, 。
测试点编号 | ||
---|---|---|
时间限制:
空间限制: