⭐️⭐️⭐️
# 題目敘述
You are given an array of strings tokens
that represents an arithmetic expression in a Reverse Polish Notation.
Evaluate the expression. Return an integer that represents the value of the expression.
Note that:
- The valid operators are
'+'
,'-'
,'*'
, and'/'
. - Each operand may be an integer or another expression.
- The division between two integers always truncates toward zero.
- There will not be any division by zero.
- The input represents a valid arithmetic expression in a reverse polish notation.
- The answer and all the intermediate calculations can be represented in a 32-bit integer.
# Example 1
Input: tokens = ["2","1","+","3","*"]
Output: 9
Explanation: ((2 + 1) * 3) = 9
# Example 2
Input: tokens = ["4","13","5","/","+"]
Output: 6
Explanation: (4 + (13 / 5)) = 6
# Example 3
Input: tokens = ["10","6","9","3","+","-11","","/","","17","+","5","+"]
Output: 22
Explanation: ((10 * (6 / ((9 + 3) * -11))) + 17) + 5
= ((10 * (6 / (12 * -11))) + 17) + 5
= ((10 * (6 / -132)) + 17) + 5
= ((10 * 0) + 17) + 5
= (0 + 17) + 5
= 17 + 5
= 22
# 解題思路
# Solution
import java.util.*; | |
class Solution { | |
public int evalRPN(String[] tokens) { | |
ArrayList<Integer> arr = new ArrayList<>(); | |
for(int i = 0; i < tokens.length; i++){ | |
if(tokens[i].equals("+") || tokens[i].equals("-") || tokens[i].equals("*") || tokens[i].equals("/")){ | |
int temp = math(arr.get(arr.size() - 2),arr.get(arr.size() - 1),tokens[i]); | |
arr.remove(arr.size() - 1); | |
arr.remove(arr.size() - 1); | |
arr.add(temp); | |
} | |
else{ | |
arr.add(Integer.parseInt(tokens[i])); | |
} | |
} | |
return arr.get(0); | |
} | |
public int math(int a, int b, String s) { | |
switch (s) { | |
case "+": | |
return a + b; | |
case "-": | |
return a - b; | |
case "*": | |
return a * b; | |
case "/": | |
return a / b; | |
} | |
return 0; | |
} | |
} |
#include <string> | |
#include <vector> | |
#include <iostream> | |
using namespace std; | |
class Solution { | |
public: | |
int evalRPN(vector<string>& tokens) { | |
vector<int> arr; | |
for (int i = 0; i < tokens.size(); i++) { | |
if (tokens[i] == "+" || tokens[i] == "-" || tokens[i] == "*" || | |
tokens[i] == "/") { | |
int tmp = math(arr[arr.size() - 2], arr[arr.size() - 1], tokens[i]); | |
arr.pop_back(); | |
arr.pop_back(); | |
arr.push_back(tmp); | |
} else { | |
arr.push_back(stoi(tokens[i])); | |
} | |
} | |
return arr[0]; | |
} | |
int math(int a, int b, string s) { | |
switch (s[0]) { | |
case '+': | |
return a + b; | |
case '-': | |
return a - b; | |
case '*': | |
return a * b; | |
case '/': | |
return a / b; | |
} | |
return 0; | |
} | |
}; |
單字
** **
!! !!
片語 & 搭配詞
!! !!