码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Leetcode-1106. 解析布尔表达式


    题目描述:

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

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

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

    LevelAC rate
    Hard65.4%

    题目解析:

    遍历整个原字符串,将原字符串中除了 ',' 和 ')' 全部压入栈中,当遍历到)后,就将栈顶元素弹出,直到弹到 '(' ,并记录期间t和f的个数用来进行计算,然后根据 '(' 前的逻辑运算符结合我们记录的t和f的个数进行计算,将计算得到的bool值对应t和f压入栈中,最后,根据栈顶元素决定最后的返回结果布尔值,如果栈顶元素为t则返回true,若栈顶元素为f则返回false,代码如下:

    1. class Solution {
    2. public:
    3. bool parseBoolExpr(string expression) {
    4. int len = expression.size();
    5. stack<char> stk;
    6. for(int i = 0 ; i
    7. if(expression[i]==')'){
    8. int num_t = 0 , num_f = 0;
    9. while(stk.top()!='('){
    10. if(stk.top()=='t')num_t++;
    11. if(stk.top()=='f')num_f++;
    12. stk.pop();
    13. }
    14. stk.pop();
    15. char cur = stk.top();
    16. stk.pop();
    17. if(cur=='|'){
    18. char res = num_t>0?'t':'f';
    19. stk.push(res);
    20. }
    21. else if(cur=='&'){
    22. char res = num_f>0?'f':'t';
    23. stk.push(res);
    24. }
    25. else{
    26. char res = num_t>0?'f':'t';
    27. stk.push(res);
    28. }
    29. }
    30. else if(expression[i]!=','&&expression[i]!=')')stk.push(expression[i]);
    31. }
    32. return stk.top()=='f'?false:true;
    33. }
    34. };

    执行用时:4 ms, 在所有 C++ 提交中击败了89.86%的用户

    内存消耗:6.9 MB, 在所有 C++ 提交中击败了80.40%的用户

  • 相关阅读:
    Spring中Bean的生命周期
    TNS-12531: TNS: 无法分配内存
    NLP从零开始------9文本进阶处理之文本相似度计算
    反爬虫技术和策略
    【JAVA】单元测试的简单应用
    搜索服从幂律分布的网络 论文阅读
    关于maven项目中依赖无法下载的解决方案
    【luogu CF1163F】Indecisive Taxi Fee(图论)(分类讨论)
    Charles抓取接口报文并修改各种参数信息调试
    刷题笔记(十八)--二叉树:公共祖先问题
  • 原文地址:https://blog.csdn.net/rygy_/article/details/127701860
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号