C++實(shí)現(xiàn)LeetCode(150.計(jì)算逆波蘭表達(dá)式)
[LeetCode] 150.Evaluate Reverse Polish Notation 計(jì)算逆波蘭表達(dá)式
Evaluate the value of an arithmetic expression in Reverse Polish Notation.
Valid operators are +, -, *, /. Each operand may be an integer or another expression.
Note:
- Division between two integers should truncate toward zero.
- The given RPN expression is always valid. That means the expression would always evaluate to a result and there won't be any divide by zero operation.
Example 1:
Input: ["2", "1", "+", "3", "*"]
Output: 9
Explanation: ((2 + 1) * 3) = 9
Example 2:
Input: ["4", "13", "5", "/", "+"]
Output: 6
Explanation: (4 + (13 / 5)) = 6
Example 3:
Input: ["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
逆波蘭表達(dá)式就是把操作數(shù)放前面,把操作符后置的一種寫(xiě)法,我們通過(guò)觀察可以發(fā)現(xiàn),第一個(gè)出現(xiàn)的運(yùn)算符,其前面必有兩個(gè)數(shù)字,當(dāng)這個(gè)運(yùn)算符和之前兩個(gè)數(shù)字完成運(yùn)算后從原數(shù)組中刪去,把得到一個(gè)新的數(shù)字插入到原來(lái)的位置,繼續(xù)做相同運(yùn)算,直至整個(gè)數(shù)組變?yōu)橐粋€(gè)數(shù)字。于是按這種思路寫(xiě)了代碼如下,但是拿到OJ上測(cè)試,發(fā)現(xiàn)會(huì)有Time Limit Exceeded的錯(cuò)誤,無(wú)奈只好上網(wǎng)搜答案,發(fā)現(xiàn)大家都是用棧做的。仔細(xì)想想,這道題果然應(yīng)該是棧的完美應(yīng)用啊,從前往后遍歷數(shù)組,遇到數(shù)字則壓入棧中,遇到符號(hào),則把棧頂?shù)膬蓚€(gè)數(shù)字拿出來(lái)運(yùn)算,把結(jié)果再壓入棧中,直到遍歷完整個(gè)數(shù)組,棧頂數(shù)字即為最終答案。代碼如下:
解法一:
class Solution {
public:
int evalRPN(vector<string>& tokens) {
if (tokens.size() == 1) return stoi(tokens[0]);
stack<int> st;
for (int i = 0; i < tokens.size(); ++i) {
if (tokens[i] != "+" && tokens[i] != "-" && tokens[i] != "*" && tokens[i] != "/") {
st.push(stoi(tokens[i]));
} else {
int num1 = st.top(); st.pop();
int 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);
}
}
return st.top();
}
};
我們也可以用遞歸來(lái)做,由于一個(gè)有效的逆波蘭表達(dá)式的末尾必定是操作符,所以我們可以從末尾開(kāi)始處理,如果遇到操作符,向前兩個(gè)位置調(diào)用遞歸函數(shù),找出前面兩個(gè)數(shù)字,然后進(jìn)行操作將結(jié)果返回,如果遇到的是數(shù)字直接返回即可,參見(jiàn)代碼如下:
解法二:
class Solution {
public:
int evalRPN(vector<string>& tokens) {
int op = (int)tokens.size() - 1;
return helper(tokens, op);
}
int helper(vector<string>& tokens, int& op) {
string str = tokens[op];
if (str != "+" && str != "-" && str != "*" && str != "/") return stoi(str);
int num1 = helper(tokens, --op);
int num2 = helper(tokens, --op);
if (str == "+") return num2 + num1;
if (str == "-") return num2 - num1;
if (str == "*") return num2 * num1;
return num2 / num1;
}
};
類(lèi)似題目:
參考資料:
https://leetcode.com/problemset/algorithms/
到此這篇關(guān)于C++實(shí)現(xiàn)LeetCode(150.計(jì)算逆波蘭表達(dá)式)的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)計(jì)算逆波蘭表達(dá)式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言如何實(shí)現(xiàn)順序表(數(shù)據(jù)結(jié)構(gòu))
這篇文章主要介紹了C語(yǔ)言如何實(shí)現(xiàn)順序表(數(shù)據(jù)結(jié)構(gòu))問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
C語(yǔ)言設(shè)計(jì)一個(gè)閃閃的圣誕樹(shù)
本文使用C語(yǔ)言基礎(chǔ)知識(shí)在控制臺(tái)打印一個(gè)圣誕樹(shù)效果,真的很簡(jiǎn)單哦,一起通過(guò)本文學(xué)習(xí)吧2016-12-12
C++ 回調(diào)接口設(shè)計(jì)和二進(jìn)制兼容詳細(xì)
再開(kāi)發(fā)視頻編輯 SDK,SDK的回調(diào)接口設(shè)計(jì)成 C 風(fēng)格,結(jié)構(gòu)中放著一些函數(shù)指針,既然對(duì)外接口是 C++,為什么不直接使用 C++ 的虛函數(shù)?這篇文章便對(duì)這一問(wèn)題做個(gè)詳細(xì)介紹,需要的朋友可以參考一下2021-09-09
C++?重載運(yùn)算符在HotSpot?VM中的應(yīng)用小結(jié)
C++支持運(yùn)算符重載,對(duì)于Java開(kāi)發(fā)者來(lái)說(shuō),這個(gè)可能比較陌生一些,因?yàn)镴ava不支持運(yùn)算符重載,下面介紹一下HotSpot?VM中的運(yùn)算符重載,感興趣的朋友跟隨小編一起看看吧2023-09-09
教你用c++從頭開(kāi)始實(shí)現(xiàn)決策樹(shù)
從頭實(shí)現(xiàn)一個(gè)分類(lèi)決策樹(shù)分類(lèi)器似乎是一個(gè)適當(dāng)?shù)奶魬?zhàn)。這已經(jīng)被證明是一個(gè)測(cè)試但有益的學(xué)習(xí)旅程,我想分享一些我在這個(gè)過(guò)程中的主要經(jīng)驗(yàn),對(duì)c++實(shí)現(xiàn)決策樹(shù)相關(guān)知識(shí)感興趣的朋友一起看看吧2021-05-05

