题目大意:
火车从A到B要经过中转站,已知进入序列是顺序的即1~n,给定目标序列,看是否能得到。已知火车进站后不能回到A。
解题思路:
用栈模拟这个过程就可以了
代码如下:
#include<stdio.h>
#include<stdlib.h>
#include<iostream>
#include<string.h>
#include<stack>
using namespace std;
stack<int> S;
int main()
{
int n;
int a[1005];
int num[1005];
for(int i=0;i<=1000;i++)
num[i]=i;
while(cin>>n&&n)
{
while(cin>>a[1]&&a[1])
{
for(int i=2;i<=n;i++)
cin>>a[i];
int i=2,k=1;
S.push(num[1]);
while(k<=n&&i<=n+1)
{
if(S.empty()||S.top()!=a[k])
{
S.push(num[i]);
i++;
}
else
{
if(S.top()==a[k])
{
S.pop();
k++;
}
else
break;
}
}
if(S.empty())
printf("Yes\n");
else
printf("No\n");
while(!S.empty())
S.pop();
}
cout<<endl;
}
return 0;
}