1、给定两个序列,判断其中一个有没有可能是另一个序列的出栈序列。比如说给定入栈序列为{1,2,3,4,5},出栈序列为{4,5,3,2,1},那后者就是前者的出栈序列。具体步骤是什么呢?出栈操作每次只能出栈顶元素,所以用一个辅助栈来模拟这个出栈操作就可以了。一个元素需要出栈要么是马上要进栈的元素,要么是当前栈顶的元素。如果两者都不是,那就在入栈序列中找到这个元素,然后将这个元素以前的所有元素入栈。然后重复上面的步骤,直到遍历完整个出栈序列。如果最后辅助栈中还有元素,那说明该序列不是出栈序列,不然的话,栈中的所有数不都应该出栈了么?
参考代码如下:
bool IsPopSequence(int *Push, int *Pop, int nLen)
{
if(!Push || !Pop || nLen < 1)
return false;
int stack[N];
int top = -1;
int i,j;
i = j = 0;
while(i < nLen)
{
if(j < nLen && Pop[i] == Push[j])//要Pop是马上要Push的元素
{
++i;
++j;
}
//要Pop的在辅助栈顶
else if(top > -1 && Pop[i] == stack[top])
{
++i;
--top;
}
else//否则将前面的元素入栈
{
if(j >= nLen)//没有可入栈的
return false;
while(j < nLen && Pop[i] != Push[j])
{
stack[++top] = Push[j++];
}
}
}
if(top > -1)
return false;
else
return true;
}
下面给出main函数的调用:
#include<stdio.h>
const int N = 30;
int main()
{
int n,i;
int Pop[N];
int Push[N];
while(scanf("%d", &n) != EOF)
{
for(i = 0; i < n; ++i)
scanf("%d", &Push[i]);
for(i = 0; i < n; ++i)
scanf("%d", &Pop[i]);
if(IsPopSequence(Push, Pop, n))
printf("Yes\n");
else
printf("No\n");
}
return 0;
}