题解 | #栈的压入、弹出序列#
栈的压入、弹出序列
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;//辅助栈
};
查看5道真题和解析
基恩士成长空间 446人发布