欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

铁轨问题

程序员文章站 2022-04-09 12:49:02
...

某城市有一个火车站,铁轨铺设如下图所示。有n节车厢从A方向驶入车站,按进站顺序编号为1~n。你的任务是让它们按照某种特定的顺序进入B方向的铁轨并使出车站。为了重组车厢,你可以借助中转站C;这是一个可以停放任意多节车厢的车站,但由于末端封顶,驶入C的车厢必须按照相反的顺序驶出C。对于每个车厢,一旦从A进入C,就不能再回到A了;一旦从C进入B,就不能回到C了。换言之,在任意时刻,只有两种选择:A->C和C->B。铁轨问题

#include<cstdio>
#include<stack>
#include<iostream>
using namespace std;
const int MAXN = 1000 + 10;
int n,target[MAXN];
int main()
{
        int n;
        scanf("%d",&n);
        stack<int> s;
        //A为原始队列的下标,B为target的下标
        int A = 1,B = 1;
        for(int i=1;i<=n;i++)
            scanf("%d",&target[i]);
        int ok = 1;
        while(B <=n )
        {
            if(A==target[B])
            {
                A++;
                B++;
            }
            else if(!s.empty() && s.top()==target[B])
            {
                s.pop();
                B++;
            }
            else if(A<=n)
            {
                s.push(A);
                A++;
            }
            else
            {
                ok = 0;
                break;
            }
        }
        printf("%s\n",ok?"yes":"no" );

}