Java for 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 + 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;
    }
时间: 2025-01-02 12:42:04

Java for LeetCode 224 Basic Calculator的相关文章

Java for LeetCode 227 Basic Calculator II

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. You may assume that the given ex

Leetcode 224: Basic Calculator

Basic Calculator Total Accepted: 2801 Total Submissions: 18103 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

(medium)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 + or minus sign -, non-negative integers and empty spaces . You may assume that the given expression is

[LeetCode]224. Basic Calculator(模拟,栈)

题目链接:https://leetcode.com/problems/basic-calculator/#/description 题意:计算一个只含有括号.加减.非负数的表达式. 用一个栈记数,一个栈记符号. 1 class Solution { 2 public: 3 int calculate(string s) { 4 int n = s.length(); 5 stack<int> st; 6 stack<char> op; 7 int ret = 0; 8 op.pus

Leetcode 227. Basic Calculator II JAVA语言

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. You may assume that the given ex

leetcode 227. Basic Calculator II ---------- java

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. You may assume that the given ex

【LeetCode】224. Basic Calculator

Basic Calculator 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 giv

[LeetCode][JavaScript]Basic Calculator

Basic Calculator 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 giv

【Leetcode】Basic Calculator II

题目链接:https://leetcode.com/problems/basic-calculator-ii/ 题目: 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 s