1、 数据结构实验 姓名: 学号: 专业: 班级: 实验二 停车场管理程序 【实验学时】 5学时 【实验目的】 掌握栈的后进先出特点 【问题描述】 设停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列,若停车场内已停满n辆汽车,则后来的汽车只能在门外的便道上等侯,一旦有车开走,则排在便道上的第一辆车即可开入;当停车场内某辆车要离开时,在它之后开入的车辆必须先退出车场为它让路,待该辆车开出大门外,其它车辆再按原次序进入车场,每辆停放在车场的车在
2、它离开停车场时必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。
【实验程序】
#include
3、 //模拟停车场 typedef struct Car1{//车 int number;//车号 int ar_time;//到达时间 }CarNode; typedef struct{//停车场 CarNode *base;//停车场的堆栈底 CarNode *top;//停车场的堆栈顶 int stacksize; }Park; //模拟便道 typedef struct Car2{//车 int number;//车号 int ar_time;//到达时间 struct Car2 *n
4、ext; }*CarPtr; typedef struct{//便道 CarPtr front;//便道的队列的对头 CarPtr rear;//便道的队列的队尾 int length; }Shortcut; Status InitStack(Park &P){ P.base=(CarNode*)malloc(SIZE*sizeof(Car1)); if(!P.base) exit(OVERFLOW); P.top=P.base; P.stacksize=0; return OK; } St
5、atus Push(Park &P,CarNode e){//进入停车场 *P.top++=e; ++P.stacksize; return OK; } Status Pop(Park &P,CarNode &e){//离开停车场 if(P.top==P.base) printf("停车场为空。"); else { e=*--P.top; --P.stacksize; } return OK; } Status InitQueue(Shortcu
6、t &S){ S.front=S.rear=(CarPtr)malloc(sizeof(Car2)); if(!S.front||!S.rear) exit(OVERFLOW); S.front->next=NULL; S.length=0; return OK; } Status EnQueue(Shortcut &S,int number,int ar_time){//进入便道 CarPtr p; p=(CarPtr)malloc(sizeof(Car2)); if(!p) exit(OVERFLOW)
7、 p->number=number; p->ar_time=ar_time; p->next=NULL; S.rear->next=p; S.rear=p; ++S.length; return OK; } Status DeQueue(Shortcut &S,CarPtr &w){//离开便道 if(S.length == 0) printf("通道为空。"); else { w = S.front->next; S.front-
8、>next=S.front->next->next;
--S.length;
}
return OK;
}
Status Arrival(Park &P,Shortcut &S){//进站车辆的处理
int number,ar_time;
printf("请输入车牌号:");
scanf("%d",&number);
printf("进场的时刻:");
scanf("%d",&ar_time);
if(P.stacksize 9、
c.number=number;
c.ar_time=ar_time;
Push(P,c);
printf("该车应停在第%d号车道。\n",P.stacksize);
}
else
{
EnQueue(S,number,ar_time);
printf("停车场已满,请暂时停在便道的第%d个位置。\n",S.length);
}
return OK;
}
Status Leave(Park &P,Park &P1,Shortc 10、ut &S){//离站车辆的处理
int number,le_time,flag=1,money,ar_time;
printf("请输入车牌号:");
scanf("%d",&number);
printf("出场的时刻:");
scanf("%d",&le_time);
CarNode e,m;
CarPtr w;
while(P.stacksize)
{
Pop(P,e);
if(e.number==number)
{
11、flag=0;
money=(le_time-e.ar_time)*2;
ar_time=e.ar_time;
break;
}
Push(P1,e);
}
while(P1.stacksize)
{
Pop(P1,e);
Push(P,e);
}
if (flag == 0)
{
if(S.length!=0)
{
12、DeQueue(S,w);
m.ar_time=le_time;
m.number=w->number;
Push(P,m);
free(w);
printf("车牌号为%d的车已由便道进入停车场",m.number);
}
printf("停车费为%d, 总占用车位数为%d,剩余车位数为%d\n",money,P.stacksize,SIZE-P.stacksize);
}
else
{
13、 printf("停车场不存在牌号为%d的车\n", number);
}
return OK;
}
void main()
{
int m=1;
char flag;
Park P,Q;
Shortcut S;
InitStack(P);
InitStack(Q);
InitQueue(S);
while(m)
{
printf("\n 停车场管理程序 \n");
14、 printf("===============================================\n");
printf("** A 汽车进车场 **\n");
printf("** D 汽车出车场 **\n");
printf("** E 退出程序 **\n");
printf("请选择(A,D,E): ");
15、scanf("%c",&flag);
switch(flag)
{
case 'A':
case 'a':
Arrival(P,S);break; //车进入停车场
case 'D':
case 'd':
Leave(P,Q,S);break; //车离开停车场
case 'E':
case 'e':
m=0;
break;
default:
printf("Input error!\n");
break;
}
while (flag != '\n')
scanf("%c",&flag);
}
}






