成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Leetcode[224] Basic Calculator

William_Sang / 1163人閱讀

摘要:復(fù)雜度思路將字符串先轉(zhuǎn)換成后綴表達(dá)式,再將其出來。

Leetcode[224] Basic Calculator

Implement a basic calculator to evaluate a simple expression string.

The expression string may contain open ( and closing parentheses ),
the plus +, minus sign - or * or /, 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
"1 + (2 - 3 * 4)" = -9;
Stack

復(fù)雜度
O(N), O(N)

思路
將字符串先轉(zhuǎn)換成后綴表達(dá)式,再將其evaluate出來。
前后綴表達(dá)式的轉(zhuǎn)換:
http://scriptasylum.com/tutor...
后綴表達(dá)式的evaluation:
http://scriptasylum.com/tutor...

代碼

public int basicCalculator(String s) {
    s = s.trim().replaceAll(" +", "");
    Stack stack = new Stack<>();
    StringBuilder builder = new StringBuilder();
    char[] arr = s.toCharArray();
    for(int i = 0; i < arr.length; i ++) {
        if(arr[i] == "(") {
            stack.push("(");
        }
        else if(arr[i] == ")") {
            while(!stack.isEmpty() && stack.peek() != "(") {
                builder.append(stack.pop());
            }
            // pop out the "("
            stack.pop();
        }
        else if(Character.isDigit(arr[i])) {
            int val = 0;
            for(int j = i; j < arr.length && Character.isDigit(arr[j]); j ++) {
                val *= 10;
                val += arr[j] - "0";
            }
            builder.append(val);
            i = j - 1;
        }
        else {
            while(!stack.isEmpty() && rank(stack.peek()) >= rank(arr[j])) {
                builder.append(stack.pop());
            }
            stack.push(arr[j]);
        }
    }
    while(!stack.isEmpty()) {
        builder.append(stack.pop());
    }
    return evaluate(builder.toString());
}

public int rank(Character ch) {
    if(ch == "+" || ch == "-") return 1;
    else if(ch == "*" || ch == "/") return 2;
    // "("
    return 0;
}

public int evaluate(String s) {
    char[] arr = s.toCharArray();
    Stack stack = new Stack<>();
    for(int i = 0; i < arr.length; i ++) {
        if(Character.isDigit(arr[i])) {
            stack.push(arr[i] - "0");
        }
        else {
            int op2 = stack.pop();
            int op1 = stack.pop();
            if(arr[i] == "+") {
                stack.push(op1 + op2);
            }
            else if(arr[i] == "-") {
                stack.push(op1 - op2);
            }
            else if(arr[i] == "*") {
                stack.push(op1 * op2);
            }
            else {
                stack.push(op1 / op2);
            }
        }
    }
    return stack.pop();
}

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/66320.html

相關(guān)文章

  • [LeetCode] 224. Basic Calculator

    Problem 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 e...

    xiangzhihong 評論0 收藏0
  • 224. Basic Calculator & 227. Basic Calculator

    摘要:題目鏈接,就是感覺條件有點(diǎn)多簡單點(diǎn)的寫法,把直接用存在里面,就存成,存成題目鏈接這題就是碰到在加減后面怎么處理的問題。用一個來表示之前的,所以碰到現(xiàn)在是乘的時候就,除類似。 224. Basic Calculator 題目鏈接:https://leetcode.com/problems... stack,就是感覺條件有點(diǎn)多 public class Solution { pub...

    _DangJin 評論0 收藏0
  • Leetcode[227] Basic Calculator II

    摘要:復(fù)雜度思路用兩個來分別記錄當(dāng)前的結(jié)果和操作符注意每一次統(tǒng)計當(dāng)前的的時候,要看一下下一位的操作符。有一種的方法,是表示的是匹配任意的空白符,包括空格,制表符,換行符,中文全角空格等。也可以用更簡單的方法,。 LeetCode[227] Basic Calculator II Implement a basic calculator to evaluate a simple expres...

    chaos_G 評論0 收藏0
  • [LeetCode] 227. Basic Calculator II

    Problem 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 sho...

    silvertheo 評論0 收藏0
  • [LeetCode] 772. Basic Calculator III

    Problem 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 e...

    BlackHole1 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<