leetcode150-逆波兰表达式求值

leetcode 150

思路

本题使用栈来解决,因为符号是在数字的后面,所以一开始有数字出现的时候我们先入栈,后续遇到有符号,就出栈两个数字,让后出栈的数字作为前一位运算符,先出栈的数字作为后一位运算符,进行加减乘除的操作,操作完成后,需要把当前运算结果再次入栈,因为结果是会拿来做下一次运算的,需要注意的是,除法操作过程中,可能出现小数的情况,我们需要使用parseInt操作符来进行取整,另外stack在存储的时候不能存字符串,因为字符串相加会直接拼接,而不是进行加分运算,所以存储时需要转为数字存储

例子:tokens = ["2","1","+","3","*"]

1: stack = [2]

2: stack = [2,1]

3: 匹配到+, 需要计算2 + 1 = 3 stack = [3]

4: stack = [3,3]

5: 匹配到 乘法, 3*3 = 9 stack = [9]

实现

js 复制代码
var evalRPN = function (tokens) {
    let stack = [];
    let symbols = ['+', '-', '*', '/']
    for (const item of tokens) {
        if (symbols.includes(item)) {
            const num1 = stack.pop();
            const num2 = stack.pop();
            if (item === '+') stack.push(num2 + num1)
            if (item === '-') stack.push(num2 - num1)
            if (item === '*') stack.push(num2 * num1)
            if (item === '/') stack.push(parseInt(num2 / num1))
        } else {
            stack.push(Number(item))
        }
    }
    return stack[0];
};
相关推荐
手握风云-3 分钟前
优选算法的链脉之韵:链表专题
数据结构·算法·链表
晴殇i4 分钟前
前端内容保护:如何有效防止用户复制页面内容?
前端·javascript·css
Coding小公仔7 分钟前
LeetCode 151. 反转字符串中的单词
开发语言·c++·算法
稳兽龙7 分钟前
P1098 [NOIP 2007 提高组] 字符串的展开
c++·算法·模拟
G.E.N.12 分钟前
开源!RAG竞技场(2):标准RAG算法
大数据·人工智能·深度学习·神经网络·算法·llm·rag
写个博客17 分钟前
暑假算法日记第三天
算法
bemyrunningdog29 分钟前
二进制权限控制方案
javascript·react.js·ecmascript
汪子熙40 分钟前
深入探析 header facets:定位与应用
前端·javascript
✿ ༺ ོIT技术༻43 分钟前
剑指offer第2版:动态规划+记忆化搜索
算法·动态规划·记忆化搜索
江城开朗的豌豆1 小时前
Vue Router vs location.href:导航跳转的正确姿势,你选对了吗?
前端·javascript·vue.js