停车场管理系统C语言实现
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
一.问题描述
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={char d c b a d c b a i i i i i i i i ∈∈∈∈int,int,int,|,,,, i=1,2,3....,n,n 0≥}
数据关系:R={(i i i d b a ,,)|∈i i i d b a ,,D,∈i i i d b a ,,struct car}; 基本操作:
Judge_Output(s,q,r);//根据r 中车辆信息控制车辆是入栈s 还是 入队q 以及相关操作
A_cars(s,q, a);//将到达车辆a 的信息入栈s 或者入队q D_cars(s,q, d);//将待离开车辆d 出栈s ,并将q 中相应车辆 入栈并进行相关的操作 }ADT SqStack
2.队列抽象数据类型定义: ADT LinkQueue{
数据对象:D={∈i i i i a c b a |,,Qnode *,∈i b Qnode *,int ∈i c ,i=1,2,3....,n,n 0≥}; 数据关系:R=φ; 基本操作:
Judge_Output(s,q,r);//根据r 中车辆信息控制车辆是入栈s 还是入队q 以及相关操作 A_cars(s,q, a);//将到达车辆a 的信息入栈s 或者入队q D_cars(s,q, d);//将待离开车辆d 出栈s ,并将q 中相应车 辆入栈并进行相关的操作 }ADT LinkQueue 3.主要算法流程图:
I .Judge_Output 算法流程图:
II.A_cars算法流程图:
III.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 H[MAXSIZE];
int topp;