首页 > 其他 > 详细

227. 基本计算器 II

时间:2021-03-11 10:35:07      阅读:27      评论:0      收藏:0      [点我收藏+]

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

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

 

示例 1:

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

示例 2:

输入:s = " 3/2 "
输出:1

示例 3:

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

 

提示:

  • 1 <= s.length <= 3 * 105
  • s 由整数和算符 (‘+‘, ‘-‘, ‘*‘, ‘/‘) 组成,中间由一些空格隔开
  • s 表示一个 有效表达式
  • 表达式中的所有整数都是非负整数,且在范围 [0, 231 - 1] 内
  • 题目数据保证答案是一个 32-bit 整数

 

class Solution {
public:
    int calculate(string s) {
        int res=0,d=0;
        char sign=+;
        stack<int> nums;
        for(int i=0;i<s.size();++i){
            if(s[i]>=0){// if s[i] is a digit
                d=d*10-0+s[i];////use -‘0‘+s[i+1] instead of +s[i+1]-‘0‘ in case of 
                //Line 11: Char 31: runtime error: signed integer overflow: 2147483640 + 55 cannot be represented in type ‘int‘ (solution.cpp)
            }
            if((s[i]<0&&s[i]!= )||i==s.size()-1){
                if(sign==+){//when ‘+‘ push d
                    nums.push(d);
                }else if(sign==-){//when ‘-‘ push -d
                    nums.push(-d);
                }else if(sign==*||sign==/){
                    //when ‘*‘ pop and push nums.top()*d
                    //when ‘/‘ pop push nums.top()/d
                    int tmp=sign==*?nums.top()*d:nums.top()/d;
                    nums.pop();
                    nums.push(tmp);
                }
                sign=s[i];
                d=0;//set d back to 0
            }
        }
        while(!nums.empty()){//add all the numbers
            res+=nums.top();
            nums.pop();
        }
        return res;
    }
};

 

227. 基本计算器 II

原文:https://www.cnblogs.com/xxxsans/p/14515892.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!