Leetcode 227-基本计算器 II

题解

本题不包含括号,比较简单

双栈法(运算符栈+数字栈)

对于「任何表达式」而言,可以都使用两个栈 nums 和 ops(本题只用到了nums):

nums : 存放所有的数字

ops :存放所有的数字以外的操作

然后从前往后做,对遍历到的字符做分情况讨论:

1.空格 : 跳过

2.数字 : 从当前位置开始继续往后取,将整一个连续数字整体取出,加入 nums

num=num*10+(c[i]-'0')

细节:

对于第一个数字,其之前的运算符视为加号

若读到一个运算符,或者遍历到字符串末尾,即认为是遍历到了数字末尾

3.+ - * / ^ % :

1)遇到符号说明之前的数字遍历结束了,之前的数字num和符号preSign就要经过计算存进栈中:

乘除号:计算数字与栈顶元素,并将栈顶元素替换为计算结果。

加号:将数字压入栈;

减号:将数字的相反数压入栈;

2)将当前的符号更新为preSign,将nums置为0

bash 复制代码
class Solution {
    public int calculate(String s) {
        //数字num是和已有的运算符sign做计算
        Stack<Integer> nums=new Stack<>();
        //Stack<Character> ops=new Stack<>();
        char[] str=s.toCharArray();
        //对于第一个数字,其之前的运算符视为加号
        char preSign = '+';
        //记录当前数字大小
        int num=0;

        for(int i=0;i<str.length;i++){
            char c=str[i];
            if(c>='0'&&c<='9'){
                num=num*10+(c-'0');
            }
            //1.c不为数字,且不为空-->c是计算符号 2.遍历到了字符串末尾
            //以上情况说明前面的数字遍历结束了,遇到了下一个符号,要对前面的数字和字符做计算,计算完后再用计算结果更新数字栈,用当前字符更新符号栈

            //注意:这里一定不能和上面的if(c>'0'&&c<'9')是if..else的关系,否则最后一个数字只会进入上一个if,不会判断是否i==str.length-1
            if(!Character.isDigit(c) && s.charAt(i) != ' '||i == str.length-1){
                switch(preSign){
                    case '+':
                    nums.push(num);break;
                    case '-':
                    nums.push(-num);break;
                    case '*':
                    nums.push(nums.pop()*num);break;
                    case '/':
                    nums.push(nums.pop()/num);break;
                }
                // 更新符号为当前符号,数字清零
                preSign=c;
                num=0;
            }
        }
        // 将栈中所有结果求和就是答案
        int res = 0;
        while (!nums.isEmpty()) {
            res += nums.pop();
        }
        return res;
    }
}
相关推荐
徐归阳1 天前
第三十七天:2025 图形绘制
算法
weixin_429630261 天前
机器学习-第三章 线性模型
人工智能·算法·机器学习
补三补四1 天前
图卷积网络 (GCN)
网络·人工智能·深度学习·神经网络·算法·机器学习
未知陨落1 天前
LeetCode:82.杨辉三角
算法·leetcode
CoovallyAIHub1 天前
全球首个精细梯田地块数据集GTPBD发布:为梯田遥感研究填补空白(附数据地址)
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
【一周AI风暴】周鸿祎放话“不用AI就裁员”,前谷歌CEO鼓吹对华996血拼!
深度学习·算法·计算机视觉
Miraitowa_cheems1 天前
LeetCode算法日记 - Day 55: 子集、找出所有子集的异或总和再求和
数据结构·算法·leetcode·决策树·深度优先·剪枝
熬了夜的程序员1 天前
【LeetCode】48. 旋转图像
算法·leetcode·链表·职场和发展·深度优先
Q741_1471 天前
C++ 位运算 高频面试考点 力扣 268. 丢失的数字 题解 每日一题
c++·算法·leetcode·面试·位运算
未知陨落1 天前
LeetCode:79.跳跃游戏Ⅱ
算法·leetcode