Java for LeetCode 224 Basic Calculator

來源:互聯網
上載者:User

標籤:

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.

解題思路:

只需要確定下每個括弧後面需要帶入的符號,用Stack即可,JAVA實現如下:

    public int calculate(String s) {Stack<Integer> sign = new Stack<Integer>();sign.push(1);int lastOp = 1;int res = 0;for (int i = 0; i < s.length(); i++) {switch (s.charAt(i)) {case ‘ ‘:break;case ‘+‘:lastOp = 1;break;case ‘-‘:lastOp = -1;break;case ‘(‘:sign.push(lastOp*sign.peek());lastOp=1;break;case ‘)‘:sign.pop();break;default:int num = 0;while (i < s.length() && Character.isDigit(s.charAt(i)))num = num * 10 + s.charAt(i++) - ‘0‘;i--;res += lastOp * num * sign.peek();}}return res;    }

 

Java for LeetCode 224 Basic Calculator

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.