一.问题描述
1.实验题目:
设停车场是一个可停放 n 辆汽车的狭长通道,且只有一个大门可供汽车进出;汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列大门在最南端,最先到达的第一辆车停放在车场的最北端;若停车场内已经停满 n辆车,那么后来的车只能在门外的便道上等候;一旦有车开走,则排在便道上的第一辆车即可开入;当停车场内某辆车要离开时,在它之后进入的车辆必须先退出车场为它让路,待该辆车开出大门外,其他车辆再按原次序进入车场;每辆停放在车场的车在它离开停车场时必须按它停留的时间长短缴纳费用;试为停车场编制按上述要求进行管理的模拟程序;
要求:根据各结点的信息,调用相应的函数或者语句,将结点入栈入队,出栈或者出队;
二.需求分析
1.程序所能达到的基本可能:
程序以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入数据的序列进行模拟管理;栈以
顺序结构实现,队列以链表结构实现;同时另设一个栈,临时停放为给要离去的汽车让路而从停车场退出来的汽车;输入数据按到达或离去的时刻有序;当输入数据包括数据项为汽车的“到达”‘A’表示信息,汽车标识牌照号以及到达时刻时,应输出汽车在停车场内或者便道上的停车位置;当输入数据包括数据项为汽车的“离去”‘D’表示信息,汽车标识牌照号以及离去时刻时,应输出汽车在停车场停留的时间和应缴纳的费用便道上停留的时间不收费;当输入数据项为‘P’,0,0时,应输出停车场的车数;当输入数据项为‘W’, 0, 0时,应输出候车场车数;当输入数据项为‘E’, 0, 0,退出程序;若输入数据项不是以上所述,就输出"ERROR";
2.输入输出形式及输入值范围:
程序运行后进入循环,显示提示信息:“Please input the state,number and time of the car:”,提示用户输入车辆信息“到达”或者“离开”,车牌编号,到达或者离开的时间;若车辆信息为“到达”,车辆信息开始进栈模拟停车场,当栈满,会显示栈满信息:“The parking place is full”,同时车辆进队列模拟停车场旁便道,并显示该进入便道车辆的车牌编号,让用户知道该车的具体位置;若车辆信息为“离开”,会显示该车进入停车场的时间以及相应的停车费用,若该车较部分车早进停车场,这部分车需先退出停车场,暂时进入一个新栈为其让道,会显示进入新栈的车
辆的车牌编号及其入停车场的时间,当待离开车离开停车场后,这部分车会重新进入停车场,同时便道上的第一辆车进入停车场;若输入‘P’,0,0,会显示停车场的车数;若输入‘W’,0,0,会显示便道上的车数;若输入‘E’,0,0,程序会跳出循环,同时程序结束;若输入为其他字母,程序会显示“ERROR”报错;若便道上没有车辆停靠,会显示便道为空的信息:用户每输入一组数据,程序就会根据相应输入给出输出;输入值第一个必须为字母,后两个为数字;
3.测试数据要求:
用户输入字母时,输入大写或小写,都可以被该程序识别,正常运行;但要求用户输入数据时,三个数据项之间必须用逗号相分隔开;
三.概要设计
为了实现上述功能,该程序以栈模拟停车场以及临时停放为给要离去的汽车让路而从停车场退出来的汽车的场地,以队列模拟车场外的便道,因此需要栈和队列这两个抽象数据类型;
1.栈抽象数据类型定义:
ADT SqStack{
数据对象:D={,
i=1,,n,n}
数据关系:R={|D,struct car};
基本操作:
Judge_Outputs,q,r;列抽象数据类型定义:
ADT LinkQueue{
数据对象:D={Qnode ,Qnode
,,i=1,,n,n};
数据关系:R=;
基本操作:
Judge_Outputs,q,r;要算法流程图:
.Judge_Output算法流程图:
.A_cars算法流程图:
.D_cars算法流程图:
4.本程序保护模块:
主函数模块
栈单元模块:实现栈的抽象数据类型
队列单元模块:实现队列的抽象数据类型
调用关系:
四.详细设计
1.相关头文件库的调用说明:
include<>
include<>
define MAXSIZE 14
define n 2
define fee 10
2.元素类型、结点类型和结点指针类型:
struct car
{ char bb;
int num;
int time;
};
struct rangweicar
{int num;
int time;
};
typedef struct stackk
{struct rangweicar HMAXSIZE;
int topp;
}SqStackk;
define QNODE struct Qnode
QNODE { int data;
QNODE next;
};
3.栈类型和队列类型:
typedef struct stack
{struct car Gn;
int top;
}SqStack;
typedef struct linkqueue
{QNODE front,rear;
int geshu;
}LinkQueue;
b=='E'||r.bb=='e'
printf"STOP\n";
else ifr.bb=='P'||r.bb=='p'
printf"The number of parking cars is %d\n",s->top+1;
else ifr.bb=='W'||r.bb=='w'
printf"The number of waiting cars is %d\n",q->geshu;
else ifr.bb=='A'||r.bb=='a'
A_carss,q,r;
else ifr.bb=='D'||r.bb=='d'
D_carss,q,r;
else
printf"ERROR\n";
}
A_carsSqStack s,LinkQueue q,struct car a
{QNODE t;
ifs->top=n-1
{s->top++;
s->Gs->top.bb=;
s->Gs->top.num=;
s->Gs->top.time=;
}
else
{printf"The parking place is full\n";
t=QNODE mallocsizeofQNODE;
t->data=;
t->next=NULL;
q->rear->next=t;
q->rear=t;
printf"the number of the car in the access road is:%d\n",q->rear->data;
q->geshu++;
}
}
int D_carsSqStack s,LinkQueue q,struct car d
{int i,j,l;
float x,y;
QNODE p;
SqStackk k;
if==s->Gs->top.num
{x=s->Gs->top.time;
y=feex;
printf"The time is %.2f hours,the fee is %.2f yuan\n",x,y;
ifq->geshu==0
{printf"The queue is empty\n";
return 0;
}
else
{p=q->front->next;
q->front->next=p->next;
s->Gs->top.num=p->data;
s->Gs->top.time=;
freep;
q->geshu--;
ifq->front->next==NULL
q->rear=q->front;
return 1;
}c语言while语句流程图
}
else
{fori=0;i<s->top;i++
{ifs->Gi.num= continue;
else break;}
ifi>=s->top
{printf"ERROR\n";
return -1;
}
x=s->Gi.time;
y=feex;
printf"The time is %.2f hours,the fee is %.2f yuan\n",x,y;
k=SqStackk mallocsizeofSqStackk;
k->topp=-1;
forj=s->top;j>i;j--
{k->topp++; k->Hk->topp.num=s->Gj.num;
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论