题解 | #栈的压入、弹出序列#

栈的压入、弹出序列

https://www.nowcoder.com/practice/d77d11405cc7470d82554cb392585106

//参考了剑指offer原书的教学。
//这题的思路是构建一个辅助栈来模拟。围绕popV序列进行。popV序列中的那个数字,如果辅助栈栈顶就有,那就把辅助栈栈顶pop掉。如果没有,则去pushV序列中按照入栈顺序不断入栈(从上次截止的地方开始,在代码中体现为Pushindex不是每次循环都变为0的),直到找到popV想要出栈的数字为止。如果找到最后都没找到,说明这个数字要么不存在于PushV序列中,要么早就已经入栈了,被压在栈顶底下,出不来。
//通过这种模拟的方式即可判断。
#include <stack>
class Solution {
public:
    bool IsPopOrder(vector<int> pushV,vector<int> popV) {
        if(pushV.size()==0)
            return true;
        int Popindex=0;
        int Pushindex=0;
        bool foundInPushV=false;
        for(;Popindex<popV.size();Popindex++)
        {
            foundInPushV=false;
            if(!s.empty() && popV.at(Popindex)==s.top())//如果在辅助栈的栈顶,则弹出
            {
                s.pop();
            }else {//如果不在,就从pushV里入栈前面的数字,直到它进入到辅助栈中。如果pushV空了都没找到,判为false。
                while (Pushindex<pushV.size()) {
                    if(popV.at(Popindex)!=pushV.at(Pushindex))
                    {
                        s.push(pushV.at(Pushindex));
                        Pushindex++;
                    }else {
                        foundInPushV=true;//说明找到了。
                        Pushindex++;//进辅助栈然后再弹出辅助栈的步骤就免了
                        break;
                    }
                }
                if(foundInPushV==false)return false;
            }
        }
        return true;
    }
private:
    stack<int>s;//辅助栈
};

全部评论

相关推荐

1 收藏 评论
分享
牛客网
牛客企业服务