码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • leetcode做题笔记150. 逆波兰表达式求值


    给你一个字符串数组 tokens ,表示一个根据 逆波兰表示法 表示的算术表达式。

    请你计算该表达式。返回一个表示表达式值的整数。

    注意:

    • 有效的算符为 '+'、'-'、'*' 和 '/' 。
    • 每个操作数(运算对象)都可以是一个整数或者另一个表达式。
    • 两个整数之间的除法总是 向零截断 。
    • 表达式中不含除零运算。
    • 输入是一个根据逆波兰表示法表示的算术表达式。
    • 答案及所有中间计算结果可以用 32 位 整数表示。

    思路一:栈实现

    c语言解法

    1. bool isNumber(char* token) {
    2. return strlen(token) > 1 || ('0' <= token[0] && token[0] <= '9');
    3. }
    4. int evalRPN(char** tokens, int tokensSize) {
    5. int n = tokensSize;
    6. int stk[n], top = 0;
    7. for (int i = 0; i < n; i++) {
    8. char* token = tokens[i];
    9. if (isNumber(token)) {
    10. stk[top++] = atoi(token);
    11. } else {
    12. int num2 = stk[--top];
    13. int num1 = stk[--top];
    14. switch (token[0]) {
    15. case '+':
    16. stk[top++] = num1 + num2;
    17. break;
    18. case '-':
    19. stk[top++] = num1 - num2;
    20. break;
    21. case '*':
    22. stk[top++] = num1 * num2;
    23. break;
    24. case '/':
    25. stk[top++] = num1 / num2;
    26. break;
    27. }
    28. }
    29. }
    30. return stk[top - 1];
    31. }

    分析:

    本题要求根据逆波兰表达式的算术表达式的值,根据该表达式的特性可用栈来解决,当遇到数字则存入栈中,当遇到+-等运算符时取出栈中数字进行计算并再放入栈顶,最后返回栈顶数即可

    总结:

    本题考察栈的应用,不断读取符号对栈顶数字进行运算最后即可返回答案

  • 相关阅读:
    算法综合篇专题三:二分法
    2023年项目管理工具使用趋势分析及预测
    简单学校网页设计作业 静态HTML校园博客主页 DW大学网站模板下载 大学生简单我的学校网页作品代码 个人网页制作 学生个人网页设计作业
    Kotlin 位运算
    数字电路:常见的锁存器浅析
    JVM-JAVA-类加载过程
    【web-攻击web服务器】(13.1)Web服务器配置缺陷
    element-ui和element-plus的自定义列表格用法
    为什么序列化要实现Serializable接口
    【目标检测】理论篇(3)YOLOv5实现
  • 原文地址:https://blog.csdn.net/si_mple_/article/details/133217619
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号