码迷,mamicode.com
首页 > 其他好文 > 详细

(medium)LeetCode 224.Basic Calculator

时间:2015-08-07 19:12:20      阅读:206      评论:0      收藏: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 .

You may assume that the given expression is always valid.

Some examples:

"1 + 1" = 2
" 2-1 + 2 " = 3
"(1+(4+5+2)-3)+(6+8)" = 23

 

Note: Do not use the eval built-in library function.

代码如下:

public class Solution {
    public int calculate(String s) {
       Stack<Integer>stack=new Stack<Integer>();
       int ret=0;
       int num=0;
       int sign=1;
       for(int i=0;i<s.length();i++){
           char c=s.charAt(i);
           if(Character.isDigit(c)){
               num=10*num+c-‘0‘;
           }
           else if(c==‘+‘){
               ret+=sign*num;
               num=0;
               sign=1;
           }else if(c==‘-‘){
               ret+=sign*num;
               num=0;
               sign=-1;
           }else if(c==‘(‘){
               stack.push(ret);
               stack.push(sign);
               sign=1;
               ret=0;
           }else if(c==‘)‘){
               ret+=sign*num;
               num=0;
               ret*=stack.pop();
               ret+=stack.pop();
           }
       }
       if(num!=0) ret+=sign*num;
       return ret;
    }
}

  运行结果:

技术分享

(medium)LeetCode 224.Basic Calculator

标签:

原文地址:http://www.cnblogs.com/mlz-2019/p/4711224.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!