当前位置: 首页 > news >正文

java实现力扣计算器

代码实现中,若读到一个运算符,或者遍历到字符串末尾,即认为是遍历到了数字末尾。处理完该数字后,更新 preSign为当前遍历的字符。减号的时候则压入-dig即可

class Solution {
    public int calculate(String s) {
        Stack<Integer> stack = new Stack<Integer>();
        char preSign='+';
        int sum=0;
        int dig=0;
        int n=s.length();
        for(int i=0;i<n;i++){//为什么是++i
            char temp= s.charAt(i);
            if(Character.isDigit(temp)){
                dig =dig*10+temp-'0';
            }
            //整体就是一遇到符
            //i==n-1是为了达到字符串结尾时将数字放入栈中
            if(i==n-1||!Character.isDigit(temp)&& temp != ' ' ){
                switch(preSign){
                    default:
                        stack.add(dig);
                        break;
                    case '-':
                        stack.add(-dig);
                        break;
                    case '*':
                        stack.add(stack.pop()*dig);
                        break;
                    case '/':
                        stack.add(stack.pop()/dig);
                        break;
                }
                preSign=temp;
                dig=0;


            }
        }
        for(int number:stack){
            sum=sum+number;
        }

        return sum;
    }
}
http://www.dtcms.com/a/1582.html

相关文章:

  • Nginx 解决内容安全策略CSP(Content-Security-Policy)配置方式
  • Leetcode55. 跳跃游戏
  • 基于若依ruoyi-nbcio增加flowable流程待办消息的提醒,并提供右上角的红字数字提醒(八)
  • StartUML 5.1.0文本框中文自动换行和排版问题解决
  • Python:Django框架的Hello wrold示例
  • matlab读写json文件
  • unity自己对象池的使用
  • CHAPTER 10: DESIGN A NOTIFICATION SYSTEM
  • C/C++统计满足条件的4位数个数 2023年5月电子学会青少年软件编程(C/C++)等级考试一级真题答案解析
  • python装13的一些写法
  • flume安装及实战
  • 数据库选型参考
  • 数据分享|R语言生态学种群空间点格局分析:聚类泊松点过程对植物、蚂蚁巢穴分布数据可视化...
  • 【Linux】Linux环境基础开发工具使用
  • 多线程带来的的风险-线程安全
  • MySQL集群高可用架构之MMM
  • 设计模式-代理模式
  • 【python爬虫】—星巴克产品
  • 【C语言】指针经典笔试题(上)
  • [Linux入门]---git命令行的基本使用
  • pytorch生成CAM热力图-单张图像
  • Python实现简单的爬虫功能
  • CListCtrl设置只显示单列
  • RabbitMQ配置文件_修改RabbitMQ MQTT的1883端口
  • OJ练习第180题——颠倒二进制位
  • 我的创作纪念日
  • 多维时序 | MATLAB实现WOA-CNN-GRU-Attention多变量时间序列预测(SE注意力机制)
  • 怎么实现一个登录时需要输入验证码的功能
  • 【【萌新的FPGA学习之初识ZYNQ】】
  • 小程序从无到有教学教程-- 01.重置华为云服务器Huawei Cloud EulerOS 2.0版本并且设置安全组