面试100题系列之16判断序列是不是Pop序列

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


你可能感兴趣的:(面试100题系列之16判断序列是不是Pop序列)