力扣 LeetCode 150. 逆波兰表达式求值(Day5:栈与队列)

解题思路:

逆波兰表达式就是从二叉树的后序遍历得来的(左右根),因此计算机直接按顺序取出表达式中元素进行运算即可,无需考虑括号的运算顺序,加快运算速度

对于(1+2)x(3+4)会表示为1 2 + 3 4 + x

注意:

  1. Deque中的泛型应该是Integer而不是String,整个运算过程中,只有int类型的数字才放入过栈中,全程没有放入String类型的运算符号

  2. 对于字符串的比较,应该使用 equals() 方法

  3. 第一个 pop() 出的值是 num2 而不是 num1 ,因为1 2 放入栈中后为 2 1,在栈顶的数值是2,而正确的运算顺序是先1后2

  4. 给定的是 String[] ,逐一将数字放入栈中时,需要使用 Integer.parseInt() 方法转化成 int 类型

(使用 Integer.valueOf() 方法转化成 Integer 包装类型也可以)

java 复制代码
class Solution {
    public int evalRPN(String[] tokens) {
        Deque<Integer> stack = new ArrayDeque<>();
        for (String s : tokens) {
            if (s.equals("+") || s.equals("-") || s.equals("*") || s.equals("/")) {
                int num2 = stack.pop();
                int num1 = stack.pop();
                if (s.equals("+")) stack.push(num1 + num2);
                else if (s.equals("-")) stack.push(num1 - num2);
                else if (s.equals("*")) stack.push(num1 * num2);
                else if (s.equals("/")) stack.push(num1 / num2);
            } else {
                stack.push(Integer.parseInt(s));
            }
        }
        return stack.pop();
    }
}
相关推荐
Q741_14721 分钟前
每日一题 力扣 3655. 区间乘法查询后的异或 II 模拟 分治 乘法差分法 快速幂 C++ 题解
c++·算法·leetcode·模拟·快速幂·分治·差分法
The_Ticker22 分钟前
印度股票实时行情API(低成本方案)
python·websocket·算法·金融·区块链
夏乌_Wx26 分钟前
剑指offer | 2.4数据结构相关题目
数据结构·c++·算法·剑指offer·c/c++
AI成长日志1 小时前
【笔面试算法学习专栏】哈希表基础:两数之和与字母异位词分组
学习·算法·面试
abant21 小时前
leetcode 239 单调队列 需要一些记忆
算法·leetcode·职场和发展
漫霂1 小时前
二叉树的统一迭代遍历
java·算法
炽烈小老头2 小时前
【每天学习一点算法 2026/04/08】阶乘后的零
学习·算法
Mr_Xuhhh2 小时前
算法刷题笔记:从滑动窗口到哈夫曼编码,我的算法进阶之路
开发语言·算法
MicroTech20252 小时前
突破虚时演化非酉限制:MLGO微算法科技发布可在现有量子计算机运行的变分量子模拟技术
科技·算法·量子计算
hssfscv2 小时前
软件设计师下午题六——Java的各种设计模式
java·算法·设计模式