227. Basic Calculator II 224. Basic Calculator

88 篇文章 0 订阅
42 篇文章 0 订阅

你确定面试的时候用逆波兰表达式??

 

Implement a basic calculator to evaluate a simple expression string.

The expression string may contain open ( and closing parentheses ), the plus + or minus sign -non-negative integers and empty spaces .

Example 1:

Input: "1 + 1"
Output: 2

Example 2:

Input: " 2-1 + 2 "
Output: 3

Example 3:

Input: "(1+(4+5+2)-3)+(6+8)"
Output: 23

Note:

  • You may assume that the given expression is always valid.
  • Do not use the eval built-in library function.

import java.util.Stack;

class Solution {
    public int calculate(String s) {
        char[]cs=s.toCharArray();
        Stack<Integer>st=new Stack<Integer>();
        int sign = 1, res = 0;
        
        for(int i=0; i<cs.length; i++) {
        	if(Character.isDigit(cs[i])) {
        		int sum=cs[i]-'0';
        		while(i+1<cs.length && Character.isDigit(cs[i+1])) {
        			sum = sum*10 + cs[i+1]-'0';
        			i++;
        		}
        		res += sum*sign;
        	} else if(cs[i]=='+') {
        		sign = 1;
        	} else if(cs[i]=='-') {
        		sign = -1;
        	} else if(cs[i]=='(') {
        		st.push(res);  //把之前的结果先放到stack中去
        		st.push(sign);
        		res = 0;
        		sign = 1;
        	} else if(cs[i]==')') {
        		res = st.pop() * res + st.pop();
        	}
        }
        
        return res;
    }
}

 

 

Implement a basic calculator to evaluate a simple expression string.

The expression string contains only non-negative integers, +-*/ operators and empty spaces . The integer division should truncate toward zero.

Example 1:

Input: "3+2*2"
Output: 7

Example 2:

Input: " 3/2 "
Output: 1

Example 3:

Input: " 3+5 / 2 "
Output: 5

Note:

  • You may assume that the given expression is always valid.
  • Do not use the eval built-in library function.

 


class Solution {
    public int calculate(String s) {
    	char[]cs=s.replace(" ", "").toCharArray();
    	int res=0, preVal=0, curVal=0;
    	char sign = '+';
		
		for(int i=0; i<cs.length; i++) {
			curVal = 0;
    		while(i<cs.length && Character.isDigit(cs[i])) {
    			curVal = curVal*10 + cs[i]-'0';
    			i++;
    		}
    		
    		if(sign=='+') {
				res += preVal;
				preVal = curVal;
			} else if(sign=='-') {
				res += preVal;
				preVal = -curVal;
			} else if(sign=='*') {
				preVal *= curVal;
			} else if(sign=='/') {
				preVal /= curVal;
			}
    		
    		if(i!=cs.length)  sign = cs[i];
		}
		
    	return res+preVal;
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值