传送门:http://oj.cnuschool.org.cn/oj/home/problem.htm?problemID=15
20602铁轨 |
难度级别:B; 运行时间限制:1000ms; 运行空间限制:51200KB; 代码长度限制:2000000B |
试题描述 |
某城市有一个火车站,铁轨铺设如图所示,有n节车厢从A方向驶入车站,按进站顺序编号为1至n。你的任务是判断是否能让它们按照某种特定的顺序进入B方向的铁轨并驶出车站。为了重组车厢,你可以借助中转站C。这是一个可以停放任意多节车厢的车站,但由于末端封顶,驶入C的车厢必须按照相反的顺序驶出车站。例如:出站顺序(5,4,1,2,3)是不可能的,而(5,4,3,2,1)是可能的。对于每节车厢,一旦从A移入C,就不能再回到A了;一旦从C移入B,就不能回到C了。换句话说,在任意时刻,只有两种选择A->C和C->B。 |
输入 |
两行,第一行有一个正整数n,表示有n节车厢,第二行有n个正整数,即1到n的一种排列,两两之间有一个空格分隔。 |
输出 |
yes或者no |
输入示例 |
5 5 4 1 2 3 |
输出示例 |
no |
其他说明 |
对于 100%的数据,0 < n ≤ 100。 |
栈瞎搞
#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<stack>
using namespace std;
int n,A[+],top=;stack<int>S;
inline int read(){
int x=,sig=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-') sig=-;ch=getchar();}
while(isdigit(ch)) x=*x+ch-'',ch=getchar();
return x*=sig;
}
inline void write(int x){
if(x==){putchar('');return;} if(x<) putchar('-'),x=-x;
int len=,buf[]; while(x) buf[len++]=x%,x/=;
for(int i=len-;i>=;i--) putchar(buf[i]+'');return;
}
void init(){
n=read();
for(int i=;i<=n;i++) A[i]=read();
top=;
return;
}
void work(){
int tmp;
for(int i=;i<=n;i++){
S.push(i);
while(!S.empty()&&S.top()==A[top]){
S.pop();top++;
}
}
return;
}
void print(){
if(S.empty()) puts("yes");
else puts("no");
return;
}
int main(){
init();work();print();return ;
}