摘要:復(fù)雜度思路將字符串先轉(zhuǎn)換成后綴表達(dá)式,再將其出來。
Leetcode[224] Basic Calculator
StackImplement 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;
復(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(" +", ""); Stackstack = 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
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...
摘要:題目鏈接,就是感覺條件有點(diǎn)多簡單點(diǎn)的寫法,把直接用存在里面,就存成,存成題目鏈接這題就是碰到在加減后面怎么處理的問題。用一個來表示之前的,所以碰到現(xiàn)在是乘的時候就,除類似。 224. Basic Calculator 題目鏈接:https://leetcode.com/problems... stack,就是感覺條件有點(diǎn)多 public class Solution { pub...
摘要:復(fù)雜度思路用兩個來分別記錄當(dāng)前的結(jié)果和操作符注意每一次統(tǒng)計當(dāng)前的的時候,要看一下下一位的操作符。有一種的方法,是表示的是匹配任意的空白符,包括空格,制表符,換行符,中文全角空格等。也可以用更簡單的方法,。 LeetCode[227] Basic Calculator II Implement a basic calculator to evaluate a simple expres...
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...
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...
閱讀 3119·2023-04-25 15:44
閱讀 1889·2019-08-30 13:11
閱讀 2849·2019-08-30 11:11
閱讀 3071·2019-08-29 17:21
閱讀 1318·2019-08-29 15:38
閱讀 962·2019-08-29 12:49
閱讀 1809·2019-08-28 18:19
閱讀 3234·2019-08-26 14:01