• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

LeetCode 2 Evaluate Reverse Polish Notation

mysql 搞代码 4年前 (2022-01-09) 22次浏览 已收录 0个评论

Evaluate the value of arithmetic expression in Reverse Polish Notation. Valid operator are ,-,*,/. Each operand may be an integer or another expression. Some examples: [2, 1, , 3, *] – ((21)*3) – 9 [4, 13, 5, /, ] – (本文来源gao($daima.com搞@代@#码8网^4 (13 / 5)) – 6 分析:

Evaluate the value of arithmetic expression in Reverse Polish Notation.

Valid operator are +,-,*,/. Each operand may be an integer or another expression.

Some examples:

[“2”, “1”, “+”, “3”, “*”] -> ((2+1)*3) -> 9

[“4”, “13”, “5”, “/”, “+”] -> (4 + (13 / 5)) -> 6

分析:后缀表达式操作。

栈的应用,如果碰见数字,则压栈,碰见运算符则弹出两个元素,对两个元素进行数学运算后结果压栈。

public class Solution {    public int evalRPN(String[] tokens) {        Stack st = new Stack();        for(String token : tokens){            if(token.matches("-?[0-9]+")){                st.push(Integer.parseInt(token));            }else{                int num2 = st.pop();                int num1 = st.pop();                if(token.equals("+")){                    st.push(num1+num2);                }else if(token.equals("-")){                    st.push(num1-num2);                }else if(token.equals("*")){                    st.push(num1*num2);                }else if(token.equals("/")){                    st.push(num1/num2);                }            }         }        return st.pop();    }}

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:LeetCode 2 Evaluate Reverse Polish Notation
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址