//目录

火车进出站(POJ1363)

题目链接:http://poj.org/problem?id=1363

 

 

#include <stdio.h>
#include <stack>

using namespace std;

int ans[10000]; ///出栈秩序

int main()
{
    int t;  ///有多少车厢
    while(scanf("%d",&t),t)
    {
        stack<int>s;
        while(scanf("%d",&ans[0]),ans[0])
        {
            for(int i=1;i<t;i++)
                scanf("%d",&ans[i]);

            ///模拟进栈
            int k,i;
            for(i=1,k=0;i<=t;i++)
            {
                s.push(i);
                while(s.top()==ans[k])
                {
                    if(!s.empty()) s.pop();
                    k++;
                    if(s.empty()) break;
                }
            }
            if(k==t) printf("Yes\n");
            else printf("No\n");
        }
        printf("\n");
    }

    return 0;
}
View Code

 

posted @ 2016-04-20 21:02  小草的大树梦  阅读(415)  评论(0编辑  收藏  举报