![](https://images0.cnblogs.com/blog/751746/201507/242320382721745.jpg)
首先来看图,来看下压入顺序是1、2、3、4、5.弹出顺序是4、5、3、2、1
的情况下的栈的顺序:
![](https://images0.cnblogs.com/blog/751746/201507/242320387575131.png)
是这样没错。怎么来的呢?
我们结合压入和弹出的数组来考虑。
首先我看弹出的数组:
![](https://images0.cnblogs.com/blog/751746/201507/242320393354787.png)
为什么4在最开始处呢?压入顺序是:
![](https://images0.cnblogs.com/blog/751746/201507/242320396637986.png)
说明这个栈里己经有了1、2、3、4
![](https://images0.cnblogs.com/blog/751746/201507/242320401006387.png)
于是我们弹出4。
![](https://images0.cnblogs.com/blog/751746/201507/242320406166828.png)
现在弹出顺出数组里指向了5
![](https://images0.cnblogs.com/blog/751746/201507/242320411797957.png)
现在我们栈里没有5啊?哪来的5。于是我们先压入5.
![](https://images0.cnblogs.com/blog/751746/201507/242320416948399.png)
再弹出5
![](https://images0.cnblogs.com/blog/751746/201507/242320421941313.png)
于是看我们的弹出数组现在指向了3
![](https://images0.cnblogs.com/blog/751746/201507/242320425853728.png)
我们栈里第一个就是3,那么弹出3
![](https://images0.cnblogs.com/blog/751746/201507/242320429291157.png)
同样我们弹出2,然后弹出1
![](https://images0.cnblogs.com/blog/751746/201507/242320431796613.png)
现在栈变为空了。
其实上面我们采用了逆向思维的方式,我们从弹出的数组顺序中开始推测以前的压入顺序,倒过来模拟以前的那个栈的工作过程。
如果模拟过程中压入的数字正好和我们弹出的数组相配套,那么最后栈定是空的,否则就不为空嘛。
源代码:
#ifndef IS_STACK_SEQ_H
#define IS_STACK_SEQ_H
#include<stack>
#include<iostream>
bool isStackSeq(int *arrPush,int *arrPop,int Length){
if(arrPush==NULL||arrPop==NULL||Length==0){
throw("invalid input ");
return false;
}
std::stack<int> stack_pop;
std::stack<int> stack_push;
for(int i=0;i<Length; i++){
stack_pop.push(arrPop[i]);
}
int *arrPushEnd=arrPush+Length-1;
while(arrPush<=arrPushEnd){
while(*arrPush!=stack_pop.top()){
stack_push.push(*arrPush);
arrPush++;
}
arrPush++;
stack_pop.pop();
}
while(stack_push.size()!=0){
if(stack_pop.top()!=stack_push.top()){
return false;
}else{
stack_pop.pop();
stack_push.pop();
}
}
return true;
}
#endif
测式:
#include"isTheStackSeq.h"
#include<iostream>
int main(){
int push[5]={1,2,3,4,5};
int pop[5]={5,4,3,2,1};
std::cout<<isStackSeq(push,pop,5);
}