数据结构实验之栈与队列十一:refresh的停车场

数据结构实验之栈与队列十一:refresh的停车场

Time Limit: 1000MS  Memory Limit: 65536KB
Problem Description

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

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

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

Input

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

Output

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

Example Input
2 6
Add 18353364208
Add 18353365550
Add 18353365558
Add 18353365559
Del
Out
Example Output
18353365558
18353364208
这是一个把队列和栈结合起来的题目,在通道里可以用队列模拟,而在停车场里可以用栈来模拟,不过要考虑好什么时候栈空,什么时候栈满,以及
对应什么操作。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef long long int elemtype;
typedef long long int Qelemtype;
typedef int status;
//#define MAXSIZE 200010
#define OVERFLOW -2
#define another 10010
#define QUEUESIZE 1000000
#define true 1
#define false 0
#define OK 1
int MAXSIZE;


typedef struct Qnode{
	Qelemtype data;
	struct Qnode *next;
}Qnode, *Queuenode;
typedef struct {
	elemtype *base;
	elemtype *top;
	int stacksize;
}Sqstack;
typedef struct{
	Queuenode front;
	Queuenode rear;
	int queueLength;
}linkQueue;


//Stack
void initStack(Sqstack &S){            //初始化栈
	S.base = new elemtype[MAXSIZE];
	S.top = S.base;
	S.stacksize = MAXSIZE;
}
status isEmpty(Sqstack &S){             //栈的判空
	if(S.top == S.base)
		return true;
	else
		return false;
}
status isFull(Sqstack &S){
	if((S.top-S.base) >= MAXSIZE)
		return true;
	else 
		return false;
}
elemtype getTop(Sqstack &S){           //获取栈顶元素
	if(S.base == S.top)
		return false;
	else
		return *(S.top-1);
}
void cleanStack(Sqstack &S){                 //清空栈
	S.base = S.top;
}
void Push(Sqstack &S, elemtype e){      //压栈
	if(S.top-S.base >= S.stacksize){
		S.base = (elemtype *)realloc(S.base,(another+S.stacksize)*sizeof(elemtype));
		S.top = S.base + S.stacksize;
		S.stacksize += another
		;
	}
	*S.top++ = e;
}
status Pop(Sqstack &S, elemtype &e){       //出栈
	if(S.top == S.base) return false;
	 e = * --S.top;
}


//Queue
void initQueue(linkQueue &Q){         //初始化队列
	Q.front = new Qnode;
	Q.rear = Q.front;
	if(!Q.front) exit(OVERFLOW);
	Q.front->next = NULL;
	Q.queueLength = 0;
}
void cleanQueue(linkQueue &Q){		//清空队列
	while(Q.front){
		Q.rear = Q.front->next;
		free(Q.front);
		Q.front = Q.rear;
	}
}
void enQueue(linkQueue &Q, Qelemtype e){		//元素入队列
	Queuenode p;
	p = new Qnode;
	if(!p) exit(OVERFLOW);
	p->data = e;
	p->next = NULL;
	Q.rear->next = p;
	Q.rear = p;
	Q.queueLength++;
}
void deQueue(linkQueue &Q, Qelemtype &e){		//元素出队列
	if(Q.front == Q.rear) return;
	Queuenode p;
	p = Q.front->next;
	e = p->data;
	Q.front->next = p->next;
	if(Q.rear == p)
        Q.rear = Q.front;
	free(p);
}
int QueueEmpty(linkQueue &Q){				//队列判空
	if(Q.rear  == Q.front)
		return true;
	else
		return false;
}


//主函数
int main(){
	int m;
	while(~scanf("%d %d", &MAXSIZE, &m)){
		Sqstack S;
		initStack(S);
		linkQueue Q;
		initQueue(Q);
		int flag = 1;
		char order[10];
		long long int num;
		while(m--){
			scanf("%s", order);
			if(strcmp(order, "Add") == 0){
				scanf("%lld", &num);
				if(isFull(S))
					enQueue(Q, num);
				else
					Push(S, num);
			}
			else if(strcmp(order, "Del") == 0)
			{
				if(isEmpty(S))
					flag = 0;
				else{
					    elemtype temp;
					    Pop(S, temp);
					    if(!QueueEmpty(Q)){
					    	deQueue(Q, temp);
						    Push(S, temp);
					    }
				}
			}
			else if(strcmp(order, "Out") == 0){
				if(QueueEmpty(Q))
					flag = 0;
				else{
					elemtype temp;
					deQueue(Q, temp);
				}
			}
		}
		if(!flag)
			printf("Error\n");
		else{
			while(!isEmpty(S)){
				elemtype temp;
			    Pop(S, temp);
				printf("%lld\n", temp);
			}
		}
	}
	return 0;
}





评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值