实现一个函数 terms(s:str),输入s为一合式公式,返回s的主析取范式中包含合取式的数量。其中,s中的联结词仅可能包含¬,∧,∨,分别用not,and,or表示,s中的变元包含且仅包含P,Q,R。
时间: 2024-05-19 10:15:49 浏览: 84
思路:
1. 先将字符串s转换为后缀表达式,并将所有运算符转换为对应的Python运算符。
2. 使用栈来计算后缀表达式的值,同时记录下主析取范式中包含的合取式数量。
3. 在计算过程中,如果遇到合取符号,说明当前的子表达式是一个合取式,将计数器加一。
4. 最终返回计数器的值。
代码实现如下:
def terms(s: str) -> int:
# 将运算符转换为Python运算符,并转换为后缀表达式
s = s.replace('not', 'not ').replace('and', 'and ').replace('or', 'or ')
postfix = []
stack = []
for token in s.split():
if token.isalpha():
postfix.append(token)
elif token == 'not':
stack.append('not')
elif token == 'and':
while stack and stack[-1] != 'or':
postfix.append(stack.pop())
stack.append('and')
elif token == 'or':
while stack:
postfix.append(stack.pop())
stack.append('or')
while stack:
postfix.append(stack.pop())
# 计算后缀表达式的值,同时统计合取式的数量
count = 0
stack = []
for token in postfix:
if token == 'not':
stack.append(not stack.pop())
elif token == 'and':
left = stack.pop()
right = stack.pop()
if isinstance(left, list):
count += 1
stack.append(left)
if isinstance(right, list):
count += 1
stack.append(right)
if isinstance(left, bool) and isinstance(right, bool):
stack.append(left and right)
elif token == 'or':
left = stack.pop()
right = stack.pop()
stack.append(left or right)
return count
# 测试
print(terms('P or Q'))
print(terms('not P or Q'))
print(terms('P or not Q'))
print(terms('P or Q and R'))
print(terms('P and Q or R'))
print(terms('(P or Q) and R'))
print(terms('(not P or Q) and (P or not R)'))
阅读全文