铁轨问题
题目描述
每辆火车都从A方向驶入车站C,再从B方向驶出车站C,同时它的车厢可以进行某种形式的重新组合。组合方式为:最晚驶入车站C的车厢停在最前边,可以在任意时间将停在最前边的车厢驶出车站C。假设从A方向驶来的火车有n节车厢(n<1000),分别按顺序编号为1,2,…n。假设在进入车站之前每节车厢之间都是不连着的,并且他们可以自由移动,直接倒出在B方向的铁轨上。另外假设车站C里可以停放任意多节车厢。但是一旦当一节车厢进入车站C,它就不能再回到A方向的铁轨上,并且一旦当它进入B方向的铁轨后,它就不能再回到车站C。负责车厢调度的工作人员需要知道能否使用它以a1, a2, …an的顺序从B方向输出,请写一个程序,用来判断能否得到指定的车厢顺序。
输入描述
第一行,一个整数n,表示有n节车厢;接下来一行有n个整数,表示对应顺序
输出描述
输出仅1行。若可以,则输出“Possible”否则输出“Impossible”
样例
输入
5
3 5 4 2 1
输出
Possible
题目分析
本题实质上就是对出栈的一个模拟,如果不使用STL去做,可以用数组模拟一个栈,定义一个变量top作为栈顶。
思路
以3 5 4 2 1这个出栈序列为例
- 一开始栈为空
- 由于 3 不在栈中