【LeetCode】150. 逆波兰表达式求值(ASCII码)

  今日学习的文章链接和视频链接

leetcode题目地址:150. 逆波兰表达式求值

 代码随想录题解地址:代码随想录

题目简介

即将后缀表达式转换成中缀表达式并计算。

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

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

看到题目的第一想法(可以贴代码)

1. 逆波兰表达式主要有以下两个优点:

  • 去掉括号后表达式无歧义,上式即便写成 1 2 + 3 4 + * 也可以依据次序计算出正确结果。
  • 适合用栈操作运算:遇到数字则入栈;遇到算符则取出栈顶两个数字进行计算,并将结果压入栈中。
public int evalRPN(String[] tokens) {
    Stack<String> st = new Stack<>();
    for (String i : tokens){
        if (i.charAt(0)>=48 && i.charAt(0)<=57 || i.charAt(0)=='-' && i.length() != 1){
            st.push(i);
        }else if (i.charAt(0)=='+'){
            int num1 = Integer.parseInt(st.pop());
            int num2 = Integer.parseInt(st.pop());
            int sum = num1 + num2;
            st.push(Integer.toString(sum));
        }else if (i.charAt(0)=='-' && i.length() == 1){
            int num1 = Integer.parseInt(st.pop());
            int num2 = Integer.parseInt(st.pop());
            int sum = num2 - num1;
            st.push(Integer.toString(sum));
        }else if (i.charAt(0)=='*'){
            int num1 = Integer.parseInt(st.pop());
            int num2 = Integer.parseInt(st.pop());
            int sum = num1 * num2;
            st.push(Integer.toString(sum));
        }else if (i.charAt(0)=='/'){
            int num1 = Integer.parseInt(st.pop());
            int num2 = Integer.parseInt(st.pop());  
            int sum = num2 / num1;
            st.push(Integer.toString(sum));
        }
    }
    return Integer.parseInt(st.pop());
}

实现过程中遇到哪些困难

看完代码随想录之后的想法

【解题思路】利用栈解,与我的一致,但用的是Deque。

【想法】

1. 好像一般都用Deque-LinkedList数据类型而不用Stack。

2. 先判定加减乘除更快。

看完视频自己写的ACC:

public int evalRPN(String[] tokens) {
    Deque<Integer> st = new LinkedList<>();
    for (String i : tokens){
        if (i.equals("+")){
            st.push(st.pop()+st.pop());
        }else if (i.equals("-")){
            st.push(-st.pop()+st.pop());
        }else if (i.equals("*")){
            st.push(st.pop()*st.pop());
        }else if (i.equals("/")){
            int temp1 = st.pop();
            int temp2 = st.pop();
            st.push(temp2/temp1);
        }else {
            st.push(Integer.valueOf(i));
        }
    }
    return st.pop();
}

学习时长


今日收获

1. ASCII码:

空格(32)

圆括号、加减乘除(40~47)

0~9(48~57)

A~B(65~90)

a~b(97~122)

2. String转char和int

 1 如何将字串 String 转换成整数 int ?
  • 1、 int i = Integer.parseInt([String]);
  • 2、 int i = Integer.valueOf(my_str).intValue();

注: 字串转成 Double, Float, Long 的方法大同小异.

2 如何将整数 int 转换成字串 String ?
  • 1、String s = String.valueOf(i);
  • 2、String s = Integer.toString(i);
  • 3、String s = "" + i;

 注: Double, Float, Long 转成字串的方法大同小异.

3. 关于String的加法

        String a = "12";

        String b = "13";

        System.out.println(a+b);        //输出1213而不是25