当前位置: 首页 > 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;
    }
}

相关文章:

  • 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命令行的基本使用
  • 中国与柬埔寨签署产供链经济合作谅解备忘录
  • 运油-20亮相中埃空军联训
  • 马拉松夺冠机器人将小批量量产:价格与一台入门级小轿车差不多
  • 多地市场监管部门公开征集居民水电气计量不准确、收费不规范问题线索
  • 林诗栋4比1战胜梁靖崑,晋级世界杯男单决赛将和雨果争冠
  • 五一假期出行预订进入高潮:酒店搜索热度翻倍,“请4休11”拼假带动长线游