栈之停车场

数据结构实验之栈与队列十一:refresh的停车场
Time Limit: 1000 ms Memory Limit: 65536 KiB

Problem Description
refresh最近发了一笔横财,开了一家停车场。由于土地有限,停车场内停车数量有限,但是要求进停车场的车辆过多。当停车场满时,要进入的车辆会进入便道等待,最先进入便道的车辆会优先

进入停车场,而且停车场的结构要求只出去的车辆必须是停车场中最后进去的车辆。现告诉你停车场容量N以及命令数M,以及一些命令(Add num 表示车牌号为num的车辆要进入停车场或便道,

Del 表示停车场中出去了一辆车,Out 表示便道最前面的车辆不再等待,放弃进入停车场)。假设便道内的车辆不超过1000000.

Input
输入为多组数据,每组数据首先输入N和M(0< n,m <200000),接下来输入M条命令。

Output
输入结束后,如果出现停车场内无车辆而出现Del或者便道内无车辆而出现Out,则输出Error,否则输出停车场内的车辆,最后进入的最先输出,无车辆不输出。

Sample Input
2 6
Add 18353364208
Add 18353365550
Add 18353365558
Add 18353365559
Del
Out
Sample Output
18353365558
18353364208
Hint
Source

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
long long int a[1000001],b[1000001];
int main()
{
    int n,m;
    long long int  x;
    char p[6];
    while(~scanf("%d%d",&n,&m))
    { int fa=1,ra=1,fb=1,rb=1;
    int f=0;
        while(m--)
        {
            scanf("%s",p);
            if(!strcmp(p,"Add"))
            {
                scanf("%lld",&x);
                if(ra==n+1)
                {
                    b[rb++]=x;
                }
                else a[ra++]=x;
            }

           else if(!strcmp(p,"Del"))
            {
                if(fa==ra)
                {
                    f=1;
                }
                else
                {
                    ra--;
                    if(fb!=rb)
                    {
                        a[ra++]=b[fb++];
                    }
                }
            }
            else if(!strcmp(p,"Out"))
            {
                if(fb==rb)
                {
                    f=1;
                }
                else fb++;
            }
        }
        if(f==1)
        {
            printf("Error\n");
        }
        else
        {
            while(ra>1)
            {
                printf("%lld\n",a[--ra]);
            }
        }

    }return 0;
}

用数组模拟,最后因为前面ra++,所以最后的while那样用

猜你喜欢

转载自blog.csdn.net/bhliuhan/article/details/80310299