题意描述:
给你一个字符串数组 tokens ,表示一个根据 逆波兰表示法 表示的算术表达式。
请你计算该表达式。返回一个表示表达式值的整数。
类似于二叉树,可以将运算符号看做二叉树的中间节点,遇到运算符之后计算前两个数字与该运算符的运算结果。
C++代码如下:
class Solution {
public:
int evalRPN(vector<string>& tokens) {
stack<long long> st;
for(int i = 0; i < tokens.size(); i++){
if(tokens[i] == "+" || tokens[i] == "-" || tokens[i] == "*" || tokens[i] == "/"){
long long num1 = st.top();
st.pop();
long long num2 = st.top();
st.pop();
if(tokens[i] == "+"){
st.push(num2 + num1);
}
if(tokens[i] == "-"){
st.push(num2 - num1);
}
if(tokens[i] == "*"){
st.push(num2 * num1);
}
if(tokens[i] == "/"){
st.push(num2 / num1);
}
}
else{
st.push(stoll(tokens[i]));
}
}
int res = st.top();
st.pop();
return res;
}
};