当前位置: 首页 > news >正文

LeetCode:150. 逆波兰表达式求值—栈

🍎道阻且长,行则将至。🍓

🌻算法,不如说它是一种思考方式🍀


算法专栏: 👉🏻123


一、🌱150. 逆波兰表达式求值

  • 题目描述:给你一个字符串数组 tokens ,表示一个根据 逆波兰表示法 表示的算术表达式。
    请你计算该表达式。返回一个表示表达式值的整数。
  • 来源:力扣(LeetCode)
  • 难度:简单
  • 提示:
    1 <= tokens.length <= 104
    tokens[i] 是一个算符("+"、"-"、"*" 或 "/"),或是在范围 [-200, 200] 内的一个整数
  • 注意:
    有效的算符为'+'、'-'、'*' 和 '/'
    每个操作数(运算对象)都可以是一个整数或者另一个表达式。
    两个整数之间的除法总是 向零截断 。
    表达式中不含除零运算。
    输入是一个根据逆波兰表示法表示的算术表达式。
    答案及所有中间计算结果可以用 32 位 整数表示。

逆波兰表达式
逆波兰表达式是一种后缀表达式,所谓后缀就是指算符写在后面。
平常使用的算式则是一种中缀表达式,如 ( 1 + 2 ) * ( 3 + 4 )
该算式的逆波兰表达式写法为 ( ( 1 2 + ) ( 3 4 + ) * )
逆波兰表达式主要有以下两个优点
去掉括号后表达式无歧义,上式即便写成 1 2 + 3 4 + * 也可以依据次序计算出正确结果。
适合用栈操作运算:遇到数字则入栈;遇到算符则取出栈顶两个数字进行计算,并将结果压入栈中。

🌴解题

1.使用栈

遇到数字则入栈;遇到算符则取出栈顶两个数字进行计算,并将结果压入栈中:

  • code
class Solution {public int evalRPN(String[] tokens) {Stack<String> stack=new Stack<>();int ans=0;for (String token:tokens) {switch (token){case "+":ans= Integer.parseInt(stack.pop())+Integer.parseInt(stack.pop());stack.push(String.valueOf(ans));break;case "-":ans= Integer.parseInt(stack.pop());ans=Integer.parseInt(stack.pop())-ans;stack.push(String.valueOf(ans));break;case "*":ans= Integer.parseInt(stack.pop())*Integer.parseInt(stack.pop());stack.push(String.valueOf(ans));break;case "/":ans= Integer.parseInt(stack.pop());ans=Integer.parseInt(stack.pop())/ans;stack.push(String.valueOf(ans));break;default:stack.push(token);}}int str=Integer.parseInt(stack.pop());return str;}
}

在这里插入图片描述


鹊桥仙
湛湛长空,乱云飞度,吹尽繁红。
正当年,紫金空铸,万里黄沙无觅处。
沉江望极,狂涛乍起,惊飞一滩鸥鹭。
鲜衣怒马少年时,能堪那金贼南渡?

返回第一页。☝


☕物有本末,事有终始,知所先后。🍭

🍎☝☝☝☝☝我的CSDN☝☝☝☝☝☝🍓

http://www.lryc.cn/news/57874.html

相关文章:

  • C/C++每日一练(20230410) 二叉树专场(4)
  • 策化整理1
  • 【服务通信自定义srv调用3----客户端的优化】
  • React跨域解决方案
  • 内存五区的概念,内存池技术的诞生。
  • 力扣:字符串中的第一个唯一字符(C++实现)
  • 攻防世界 favorite_number mfw、[BJDCTF2020]ZJCTF,不过如此
  • SummingMergeTree
  • JUC并发编程基础篇第一章之进程/并发/异步的概念[理解基本概念]
  • c语言—指针进阶
  • 总结二分法
  • 二叉搜索树和AVL树
  • 计算机体系结构量化研究方法【2】高速缓存Cache
  • 初识设计模式 - 迭代器模式
  • 三路快排(基于三指针单趟排序的快速排序)+快排时间复杂度再分析
  • Eyeshot Ultimate 2023 Crack
  • JAVA-8-[SpringBoot]入门程序案例和原理分析
  • 前端工程化
  • 【redis】单线程 VS 多线程(入门)
  • 2023蓝桥杯Java研究生组赛题
  • 多维时序 | MATLAB实现CNN-BiLSTM-Attention多变量时间序列预测
  • 微积分——Rolle定理的理解(罗尔定理)
  • linux内核之select/poll/epoll
  • 文件流下载
  • C语言模拟实现:atoi函数
  • LeetCode.每日一题 2427. 公因子的数目
  • 蓝牙BQB认证 - HFP profile配置说明
  • 【接口测试工具】Eolink Apikit 快速入门教程
  • 使用Python和OpenCV实现实时人脸检测并保存截图
  • [linux kernel]slub内存管理分析(7) MEMCG的影响与绕过