POJ1363 Rails 验证出栈序列问题(转)

题目地址: http://poj.org/problem?id=1363

此题只需验证是否为合法的出栈序列。

有两个思路:
1、每个已出栈之后的数且小于此数的数都必须按降序排列。复杂度O(n^2),适合人脑。

//思路 1 不对!!!

例如 数据 ,               3 5 2 4 1              --------                正确答案为 no

2、另一个思路就是直接模拟入栈出栈过程。虽然模拟毫无技巧可言,但复杂度O(n),优于算法1。适合电脑。

代码如下:

[java] view plaincopy

  1. for; i < N; i++){
  2. ifwhileelseifnullnewelse;
  3. break

----------------------------------------------------------

代码 按思路 1 做的,错误。。测试数据 ,3 5 2 4 1  正确答案应该是 no

//wrong      poj 1363
//accepted   zoj 1259
//accepted   uva 514
#include<iostream>
#include<cstring>
#include <algorithm>
using namespace std;
const int maxn=1000+10;
int main()
{
	int a[maxn];
	int b[maxn];
	int n;
	while(cin>>n && n!=0)
	{
		while(1)
		{
			memset(a,0,sizeof(a));
			memset(b,0,sizeof(b));
			int i,j;
			int x;
			cin>>a[1];
			if(a[1]==0)
				break;
			for(i=2;i<=n;i++)
				cin>>a[i];
			int max;
			int t=true;
			for(i=1;i<=n;i++)
			{
				if(b[i]!=1)
				{
					b[i]=1;
					max=a[i];
					for(j=i+1;j<=n;j++)
					{
						if(a[j]<max&&b[j]!=1)
						{
							if(a[j]!=max-1)
							{
								t=false;
								break;
							}
							else
							{
								max--;
								b[j]=1;
							}
						}
					}
				}
				if(t==false)
					break;
			}
			if(t==false)
				cout<<"No"<<endl;
			else
				cout<<"Yes"<<endl;
		}
		cout<<endl;
	}
	return 0;
}

---------------------------------------
课本 正确代码 ,较复杂。

#include<iostream>
#include<cstring>
using namespace std;
const int maxn=1000+10;
int main()
{
	int n,p[maxn];

	cin>>n;
	while(n)
	{
		int x,max=0;
		cin>>x;
		while(x)
		{
			memset(p,0,sizeof(p));
			bool valid=true;
			for(int i=1;i<=n;i++)
			{
				if(valid)
				{
					bool ok=true;
					for(int i=x+1;i<=max;i++)
						if(p[i]==1)
						{
							ok=false;
							break;
						}
					if(!ok)
						valid=false;
					else
					{
						max=(max>x?max:x);
						p[x]=2;
						for(int i=x-1;i>0 && !p[i];i--)
							p[i]=1;
					}
				}
				if(i<n)
					cin>>x;
			}
			cout<<(valid ? "Yes" : "No")<<endl;
			cin>>x;
		}
		cout<<endl;
		cin>>n;
	}
	return 0;
}

------------------------------------------------------------

POJ1363 Rails 验证出栈序列问题(转)

时间: 2024-10-10 09:10:40

POJ1363 Rails 验证出栈序列问题(转)的相关文章

【C++】 出栈序列的合法性

之前我们对栈已经有所了解,先进后出,后进先出这是栈的两大特性,那么,我们经常会碰到这种题,例: 有一组元素abcdef,按先后顺序进栈,那么出栈时哪些情况是非法的? A.    fedcba B.    abdcef C.    acbdef D.    abcdef 选哪个呢??? 很明显,根据栈的两大特性:先进后出,后进先出,即可判断,答案:C 剖析: 先看C选项acb这样的出栈序列,那么进栈肯定是abc,那么显然出栈时c肯定不会在b之前,就这么简单.用代码实现这个合法性的判断,当然也是比较

【C++】 出栈序列的合法性【面试】

之前我们对栈已经有所了解,先进后出,后进先出这是栈的两大特性,那么,我们经常会碰到这种题,例: 有一组元素abcdef,按先后顺序进栈,那么出栈时哪些情况是非法的? A.   fedcba B.   abdcef C.   acbdef D.   abcdef 选哪个呢??? 很明显,根据栈的两大特性:先进后出,后进先出,即可判断,答案:C 剖析: 先看C选项acb这样的出栈序列,那么进栈肯定是abc,那么显然出栈时c肯定不会在b之前,就这么简单.用代码实现这个合法性的判断,当然也是比较容易的,

不要搜索,出栈序列统计

1627: 出栈序列统计 时间限制: 1 Sec  内存限制: 128 MB 题目描述 栈是常用的一种数据结构,有n令元素在栈顶端一侧等待进栈,栈顶端另一侧是出栈序列.你已经知道栈的操作有两·种:push和pop,前者是将一个元素进栈,后者是将栈顶元素弹出.现在要使用这两种操作,由一个操作序列可以得到一系列的输出序列.请你编程求出对于给定的n,计算并输出由操作数序列1,2,-,n,经过一系列操作可能得到的输出序列总数. 输入 一个整数n(1<=n<=15) 输出 一个整数,即可能输出序列的总数

生成所有的出栈序列 (回溯法)

给定一个入栈序列,找出所有可能的出栈序列. 如入栈序列为 [1, 2, 3] 则可能的出栈序列为 : [ 3 2 1 ] [ 2 3 1 ] [ 2 1 3 ] [ 1 3 2 ] [ 1 2 3 ] 采用回溯法和递归统计所有可能的出栈序列. 当所有的入栈序列已经全部入栈后,则只能出栈 当栈为空时,只能进栈 当仍有入栈元素且栈不为空时,可以入栈,也可以出栈 入栈 -> 递归处理下一个入栈元素 -> 恢复未入栈状态 出栈 -> 将出栈元素添加到出栈序列 -> 递归处理下一个入栈元素

vijos - P1122出栈序列统计 (卡特兰数)

P1122出栈序列统计 未递交 标签:NOIP普及组2003[显示标签] 描写叙述 栈是经常使用的一种数据结构,有n令元素在栈顶端一側等待进栈,栈顶端还有一側是出栈序列. 你已经知道栈的操作有两·种:push和pop,前者是将一个元素进栈,后者是将栈顶元素弹出.如今要使用这两种操作.由一个操作序列能够得到一系列的输出序列. 请你编程求出对于给定的n,计算并输出由操作数序列1,2,-.n.经过一系列操作可能得到的输出序列总数. 格式 输入格式 一个整数n(1<=n<=15) 输出格式 一个整数,

给定入栈序列,求出合法的出栈序列的个数

思想:1.利用全排列函数next_permutation()求出所有可能的序列 2.从中选出所有正确的序列 #include <iostream> #include <stack> #include <vector> #include <algorithm> using namespace std; //判断序列是否是合法的出栈序列 bool IsPopOrder(const int* pPush,const int* pPop,int n) { if (p

栈-出栈序列正确性分析

问题很简单:在栈的性质下,1~n的数字按顺序入栈,给出它们的出栈序列,判定该序列是否合理. 相比于之前遇到过的“求解所有可行出栈序列”,本问题的复杂度着实降低了不少.不过要把这个过程正确地通过code模拟出来,在逻辑的处理上也需要注意不少细节. 下面先来讲讲处理的方法: 程序输入:n以及给定的出栈序列,出栈序列不妨设为q[n+1],其中q[1]~q[n]顺序保存正确性未知的出栈序列. 由于入栈是按顺序入栈,可以不用额外的数组保存,仅需要一个递增的标志A表示即可.同时,出栈序列也需要一个指针B来保

栈与队列问题1——出栈序列

问题描述:栈是常用的一种数据结构,有n个元素在栈顶端一侧等待进栈,栈顶端另一侧是出栈序列.你已经知道栈的操作有两种:push和pop,前者是将一个元素进栈,后者是将栈顶元素弹出.现在要使用这两种操作,由一个操作序列可以得到一系列的输出序列.请你编程求出对于给定的n,计算并输出由操作数序列1,2,…,n,经过一系列操作可能得到的输出序列总数. 分析:之前就有看过这种问题.就是火车进站问题,判断序列是否合法,当时是用STL栈做的.这个题只需统计次数,那么,方法就十分简便了,递归和动归都可以实现,当然

【回溯法】出栈序列统计

必三更起五更眠:最无益,莫过一日曝十日寒. [回溯法]出栈序列统计 时间限制: 1 Sec  内存限制: 128 MB提交: 17  解决: 11[提交][状态][讨论版] 题目描述 栈是常用的一种数据结构,有n令元素在栈顶端一侧等待进栈,栈顶端另一侧是出栈序列.你已经知道栈的操作有两·种:push和pop,前者是将一个元素进栈,后者是将栈顶元素弹出.现在要使用这两种操作,由一个操作序列可以得到一系列的输出序列.请你编程求出对于给定的n,计算并输出由操作数序列1,2,…,n,经过一系列操作可能得