1106. 解析布尔表达式

1、题目

给你一个以字符串形式表述的 布尔表达式(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
示例 3:

输入:expression = "&(t,f)"
输出:false
示例 4:

输入:expression = "|(&(t,f,t),!(t))"
输出:false
 

提示:

1 <= expression.length <= 20000
expression[i] 由 {'(', ')', '&', '|', '!', 't', 'f', ','} 中的字符组成。
expression 是以上述形式给出的有效表达式,表示一个布尔值。

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/parsing-a-boolean-expression
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2、思路

使用栈的方式判断字符串的逻辑值

3、代码

class Solution {
public:
    bool parseBoolExpr(string expression) {
        //声明字符栈存代表布尔值的字母
        stack<char> stk;
        //获得字符串的大小
        int n = expression.size();
        for (int i = 0; i < n; i++) {
            //获得当前下标的字符
            char c = expression[i];
            //判断字符是什么字符
            //如果是逗号则重新循环
            if (c == ',') {
                continue;
            }
            //如果不是)则入栈
            else if (c != ')') {
                stk.push(c);
            }
            //当是)时
            else {
                //声明t和f变量来储存
                int t = 0, f = 0;
                //当栈顶元素是(时退出循环
                while (stk.top() != '(') {
                    //将栈顶元素赋值给中间变量
                    char val = stk.top();
                    //弹出栈顶
                    stk.pop();
                    //判断元素是t还是f
                    if (val == 't') {
                        t++;
                    }
                    else {
                        f++;
                    }
                }
                //弹出(
                stk.pop();
                //将栈顶元素赋值给中间变量
                char op = stk.top();
                //弹出栈顶元素
                stk.pop();
                //判断字符串的逻辑逻辑运算符是什么
                switch (op) {
                case '!':
                    stk.push(f == 1 ? 't' : 'f');
                    break;
                case '&':
                    stk.push(f == 0 ? 't' : 'f');
                    break;
                case '|':
                    stk.push(t > 0 ? 't' : 'f');
                    break;
                default:
                    break;
                }
            }
        }
        //判断最终结果是什么             
        return stk.top() == 't';
    }
};

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值