其他分享
首页 > 其他分享> > 528,使用栈解基本计算器 II

528,使用栈解基本计算器 II

作者:互联网

If no one else guards the world, then I will come forward. 

如果没有别人保卫这个世界,那么我将挺身而出。

问题描述

给你一个字符串表达式s,请你实现一个基本计算器来计算并返回它的值。

整数除法仅保留整数部分。

 

示例 1:

输入:s = "3+2*2"

输出:7

示例 2:

输入:s = " 3/2 "

输出:1

示例 3:

输入:s = " 3+5 / 2 "

输出:5

 

提示:

 

使用栈解决

提示中说了,是一个有效的表达式,并且只有数字,空格和'+', '-', '*', '/'组成。我们知道算术运算式先算乘除后算加减。

 

 

所以我们可以把不能确定是否要计算的先加入到栈中,可以直接计算的先计算,然后再加入到栈中,我们随便举个例子画个图来看下

代码比较简单,我们来看下

 1public int calculate(String s) {
2    //记录每个数字前面的符号,如果是乘法和除法就直接和前面的数字运算,
3    //然后在存放到栈中,如果是加法和减法直接存放到栈中
4    int preSign = '+';
5    Stack<Integer> stack = new Stack<>();
6    int length = s.length();
7    for (int i = 0; i < length; i++) {
8        int ch = s.charAt(i);
9        if (ch == ' ')//过滤掉空格
10            continue;
11        //如果是数字
12        if (ch >= '0' && ch <= '9') {
13            //找到连续的数字字符串,把它转化为整数
14            int num = 0;
15            while (i < length && (ch = s.charAt(i)) >= '0' && ch <= '9') {
16                num = num * 10 + ch - '0';
17                i++;
18            }
19            //这个是为了抵消上面for循环中的i++
20            i--;
21            //乘法和除法,运算之后在存放到栈中。加法和减法直接存放到栈中
22            if (preSign == '*') {
23                stack.push(num * stack.pop());
24            } else if (preSign == '/') {
25                stack.push(stack.pop() / num);
26            } else if (preSign == '+') {
27                stack.push(num);
28            } else if (preSign == '-') {
29                stack.push(-num);
30            }
31        } else {//记录前一个的符号
32            preSign = ch;
33        }
34    }
35    //把栈中的所有元素都取出来,计算他们的和
36    int res = 0;
37    while (!stack.empty()) {
38        res += stack.pop();
39    }
40    return res;
41}

 

总结

算术计算,优先级高的先计算,计算的结果入栈,优先级低的直接入栈,最后再统计栈中所有元素的和即可。

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

519,单调栈解下一个更大元素 I

508,使用栈来判断有效的括号

500,验证栈序列

416,剑指 Offer-用两个栈实现队列

 

 

截止到目前我已经写了500多道算法题了,为了方便大家阅读,我把部分算法题整理成了pdf文档,目前有800多页,大家可以在公众号中回复关键字“pdf”即可获取下载链接。

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=你点的每个赞,我都认真当成了喜欢

标签:ch,int,II,num,计算,栈解,528,stack,preSign
来源: https://blog.51cto.com/u_4774266/2902952