第十四天解析布尔表达式

解析布尔表达式

问题描述:
给你一个以字符串形式表述的 布尔表达式(boolean) expression,返回该式的运算结果。

有效的表达式需遵循以下约定:

“t”,运算结果为 True
“f”,运算结果为 False
“!(expr)”,运算过程为对内部表达式 expr 进行逻辑 非的运算(NOT)
“&(expr1,expr2,…)”,运算过程为对 2 个或以上内部表达式 expr1, expr2, … 进行逻辑 与的运算(AND)
“|(expr1,expr2,…)”,运算过程为对 2 个或以上内部表达式 expr1, expr2, … 进行逻辑 或的运算(OR)

示例 1:

输入:expression = “!(f)”
输出:true
示例 2:

输入:expression = “|(f,t)”
输出:true

问题求解:

class Solution:
    def parseBoolExpr(self, expression: str) -> bool:
        def function(s):
            s=s.replace("t","True")
            s=s.replace("f","False")
            s=s.replace("&","andfun")
            s=s.replace("|","orfun")
            s=s.replace("!","notfun")
            return s

        def andfun(*args):
            result=True
            for i in args:
                result=result and i
            return result

        def orfun(*args):
            result=False
            for i in args:
                result=result or i
            return result

        def notfun(a):
            return not a

        z=function(expression)
        return eval(z)

问题总结:
老规矩我们先看一下官方求解。
方法一:栈
给定的字符串 \textit{expression}expression 是有效的布尔表达式,每个运算符后面都有一对括号,括号中有一个或多个表达式。其中,逻辑非运算符后面的括号中有一个表达式,逻辑与运算符和逻辑或运算符后面的括号中有两个或以上表达式。

可以使用栈实现布尔表达式的解析。从左到右遍历布尔表达式,对于每种类型的字符,执行相应的操作:

如果当前字符是逗号,则跳过该字符;

如果当前字符是除了逗号和右括号以外的任意字符,则将该字符添加到栈内;

如果当前字符是右括号,则一个表达式遍历结束,需要解析该表达式的值,并将结果添加到栈内:

将栈内字符依次弹出,直到栈顶字符是左括号,然后将左括号和运算符从栈内弹出,记录弹出的 \text{t'}‘t’ 和 \text{f’}‘f’ 的个数;

根据运算符以及 \text{t'}‘t’ 和 \text{f’}‘f’ 的个数计算表达式的值,并将表达式的值添加到栈内:

如果运算符是 \text{!'}‘!’,则是逻辑非运算符,表达式的值为括号内的值取反,因此当 \text{f’}‘f’ 的个数等于 11 时表达式的值为 \text{t'}‘t’,否则表达式的值为 \text{f’}‘f’;

如果运算符是 \text{\&'}‘&’,则是逻辑与运算符,当括号内的所有值都是 \text{t’}‘t’ 时结果是 \text{t'}‘t’,否则结果是 \text{f’}‘f’,因此当 \text{f'}‘f’ 的个数等于 00 时表达式的值为 \text{t’}‘t’,否则表达式的值为 \text{`f’}‘f’;

如果运算符是 \text{|'}‘|’,则是逻辑或运算符,当括号内至少有一个值都是 \text{t’}‘t’ 时结果是 \text{t'}‘t’,否则结果是 \text{f’}‘f’,因此当 \text{t'}‘t’ 的个数大于 00 时表达式的值为 \text{t’}‘t’,否则表达式的值为 \text{`f’}‘f’;

遍历结束之后,栈内只有一个字符,该字符为 \text{t'}‘t’ 或 \text{f’}‘f’,如果字符为 \text{t'}‘t’ 则返回 \text{true}true,如果字符为 \text{f’}‘f’ 则返回 \text{false}false。

作者:LeetCode-Solution
链接:https://leetcode.cn/problems/parsing-a-boolean-expression/solution/jie-xi-bu-er-biao-da-shi-by-leetcode-sol-vmvg/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值