欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)LeetCode(150.計算逆波蘭表達(dá)式)

 更新時間:2021年07月29日 14:30:15   作者:Grandyang  
這篇文章主要介紹了C++實現(xiàn)LeetCode(150.計算逆波蘭表達(dá)式),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[LeetCode] 150.Evaluate Reverse Polish Notation 計算逆波蘭表達(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ù)放前面,把操作符后置的一種寫法,我們通過觀察可以發(fā)現(xiàn),第一個出現(xiàn)的運(yùn)算符,其前面必有兩個數(shù)字,當(dāng)這個運(yùn)算符和之前兩個數(shù)字完成運(yùn)算后從原數(shù)組中刪去,把得到一個新的數(shù)字插入到原來的位置,繼續(xù)做相同運(yùn)算,直至整個數(shù)組變?yōu)橐粋€數(shù)字。于是按這種思路寫了代碼如下,但是拿到OJ上測試,發(fā)現(xiàn)會有Time Limit Exceeded的錯誤,無奈只好上網(wǎng)搜答案,發(fā)現(xiàn)大家都是用棧做的。仔細(xì)想想,這道題果然應(yīng)該是棧的完美應(yīng)用啊,從前往后遍歷數(shù)組,遇到數(shù)字則壓入棧中,遇到符號,則把棧頂?shù)膬蓚€數(shù)字拿出來運(yùn)算,把結(jié)果再壓入棧中,直到遍歷完整個數(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();
    }
};

我們也可以用遞歸來做,由于一個有效的逆波蘭表達(dá)式的末尾必定是操作符,所以我們可以從末尾開始處理,如果遇到操作符,向前兩個位置調(diào)用遞歸函數(shù),找出前面兩個數(shù)字,然后進(jìn)行操作將結(jié)果返回,如果遇到的是數(shù)字直接返回即可,參見代碼如下:

解法二:

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;
    }
};

類似題目:

Basic Calculator

Expression Add Operators

參考資料:

https://leetcode.com/problemset/algorithms/

https://leetcode.com/problems/evaluate-reverse-polish-notation/discuss/47642/a-recursive-solution-in-cpp

https://leetcode.com/problems/evaluate-reverse-polish-notation/discuss/47544/Challenge-me-neat-C%2B%2B-solution-could-be-simpler

到此這篇關(guān)于C++實現(xiàn)LeetCode(150.計算逆波蘭表達(dá)式)的文章就介紹到這了,更多相關(guān)C++實現(xiàn)計算逆波蘭表達(dá)式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++的std::transform()的實現(xiàn)

    C++的std::transform()的實現(xiàn)

    在 C++ 標(biāo)準(zhǔn)庫中,std::transform() 是一個非常有用的算法函數(shù),它能夠?qū)⒔o定范圍中的每個元素進(jìn)行變換,并將變換后的結(jié)果存儲到另一個范圍中,本文就詳細(xì)的介紹一下具體用法,感興趣的可以了解一下
    2023-08-08
  • Qt連接MySQL數(shù)據(jù)庫的實現(xiàn)(保姆級成功版教程)

    Qt連接MySQL數(shù)據(jù)庫的實現(xiàn)(保姆級成功版教程)

    本文主要介紹了Qt連接MySQL數(shù)據(jù)庫的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • C++利用PCL點云庫操作txt文件詳解

    C++利用PCL點云庫操作txt文件詳解

    這篇文章主要為大家詳細(xì)介紹了C++如何利用PCL點云庫操作txt文件,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以了解一下
    2024-01-01
  • C++中的數(shù)組你真的理解了嗎

    C++中的數(shù)組你真的理解了嗎

    這篇文章主要為大家詳細(xì)介紹了C++的數(shù)組,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • c語言strftime時間格式化示例

    c語言strftime時間格式化示例

    C/C++程序中需要程序顯示當(dāng)前時間,可以使用標(biāo)準(zhǔn)函數(shù)strftime,本文提供一個示例供大家參考
    2014-02-02
  • C++實現(xiàn)LeetCode(164.求最大間距)

    C++實現(xiàn)LeetCode(164.求最大間距)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(164.求最大間距),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 在C/C++與Python之間實現(xiàn)通信的常見方法

    在C/C++與Python之間實現(xiàn)通信的常見方法

    在C/C++與Python之間實現(xiàn)通信的方式有很多,本文給大家介紹了一些常見的方法,文中通過代碼示例介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-12-12
  • C++寫注冊表項實例

    C++寫注冊表項實例

    這篇文章主要介紹了C++寫注冊表項實例,可實現(xiàn)開機(jī)啟動的功能,是進(jìn)行Windows桌面應(yīng)用程序開發(fā)中非常重要的技巧,需要的朋友可以參考下
    2014-10-10
  • Qt5.9程序打包發(fā)布的實現(xiàn)

    Qt5.9程序打包發(fā)布的實現(xiàn)

    本文主要介紹了Qt5.9程序打包發(fā)布的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • C語言中數(shù)據(jù)結(jié)構(gòu)之鏈表歸并排序?qū)嵗a

    C語言中數(shù)據(jù)結(jié)構(gòu)之鏈表歸并排序?qū)嵗a

    這篇文章主要介紹了C語言中數(shù)據(jù)結(jié)構(gòu)之鏈表歸并排序?qū)嵗a的相關(guān)資料,需要的朋友可以參考下
    2017-05-05

最新評論