数据结构实验报告—停车场问题

数据结构实验报告—停车场问题

ID:45411600

大小:261.76 KB

页数:29页

时间:2019-11-12

数据结构实验报告—停车场问题_第1页
数据结构实验报告—停车场问题_第2页
数据结构实验报告—停车场问题_第3页
数据结构实验报告—停车场问题_第4页
数据结构实验报告—停车场问题_第5页
资源描述:

《数据结构实验报告—停车场问题》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、《计算机软件技术基础》实验报告I—数据结构实验二:停车场管理问题一、问题描述1.实验题目:设停车场是一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆车停放在车场的最北端)。若停车场内已经停满n辆车,那么后来的车只能在门外的便道上等候。一旦有车开走,则排在便道上的第一辆车即可开入。当停车场内某辆车要离开时,在它之后进入的车辆必须先退出车场为它让路,待该辆车开出大门外,其他车辆再按原次序进入车场。每辆停放在车场的车在它离开停车场时必须按它停留的时间长短缴纳费

2、用。试为停车场编制按上述要求进行管理的模拟程序。2.基本要求:以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入数据的序列进行模拟管理。每一组输入数据包括三个数据项:汽车的“到达”(‘A’表示)或“离去”(‘D’表示)信息、汽车标识(牌照号)以及到达或离去的时刻。对每一组输入数据进行操作后的输出信息为:若是车辆到达,则输出汽车在停车场内或者便道上的停车位置;若是车辆离去,则输出汽车在停车场停留的时间和应缴纳的费用(便道上停留的时间不收费)。栈以顺序结构实现,队列以链表结构实现。3.测试数据:设n=2,输入数据为:(‘A’,1,5),(‘A’,2,

3、10),(‘D’,1,15),(‘A’,3,20),(‘A’,4,25),(‘A’,5,30),(‘D’,2,35),(‘D’,4,40),(‘E’,0,0)。每一组输入数据包括三个数据项:汽车“到达”或“离去”信息、汽车牌照号码及到达或离去的时刻,其中,‘A’表示到达;‘D’表示离去,‘E’表示输入结束。其中:(‘A’,1,5)表示1号牌照车在5这个时刻到达,而(‘D’,1,15)表示1号牌照车在15这个时刻离去。二、需求分析1.程序所能达到的基本可能:本程序用来模拟一个可停放n辆车的停车场的停车管理问题。用栈和队列模拟停车场及场外通道,输入车辆状

4、态(到达或者离开),车牌号和时间,就可显示停车位置或者该车在停车场停留时间及应缴费用。2.输入的形式及输入值范围:程序接受5个命令,分别是:到达(‘A’,车牌号,时间);离去(‘D’,车牌号,时间);停车场(‘P’,0,0)显示停车场的车数;候车场(‘W’,0,0)显示候车场的车数;退出(‘E’,0,0)退出程序。3.输出的形式:对于车辆到达,要输出汽车在停车场内或者便道上的停车位置;对于车辆离去,则输出汽车在停车场停留的时间和应缴纳的费用(便道上不收费)。用户输入完毕后,程序自动运行输出运行结果。4.测试数据要求:设n=2,输入数据为:(‘A’,1

5、,5),(‘A’,2,10),(‘D’,1,15),(‘A’,3,20),(‘A’,4,25),(‘A’,5,30),(‘D’,2,35),(‘D’,4,40),(‘E’,0,0)。每一组输入数据包括三个数据项:汽车“到达”或“离去”信息、汽车牌照号码及到达或离去的时刻,其中,‘A’表示到达;‘D’表示离去,‘E’表示输入结束。其中:(‘A’,1,5)表示1号牌照车在5这个时刻到达,而(‘D’,1,15)表示1号牌照车在15这个时刻离去。三、概要设计为了实现上述功能,该程序以栈模拟停车场以及临时停放为给要离去的汽车让路而从停车场退出来的汽车的场地,以

6、队列模拟车场外的便道,因此需要栈和队列这两个抽象数据类型。1.栈抽象数据类型定义:ADTSqStack{数据对象:D={ai,bi,ci,di

7、ai∈int,bi∈int,ci∈int,di∈char),i=1,2...,n,n≥0}:数据关系:R={(ai,bi,di,)

8、ai,bi,di∈D,ai,bi,di∈structcar};基本操作:Car_enter(carnum,cartime)//将到达车辆a的信息入栈s或者入队qCar_Leave(carnum,cartime);//将待离开车辆d出栈s,并将q中相应车辆入栈并进行相关的操作Res

9、ult(charcarmove,intcarnum,intcartime)//根据输入信息完成车辆的离开或者到达}ADTSqStackADT的C语言形式说明:typedefstruct//构造一个顺序栈{structNode1home[MaxSize];intstacktop;//栈顶的指针}Stack;1.队列抽象数据类型定义ADTLinkQueue{数据对象:D={ai,bi,ci

10、ai∈Qnode*,bi∈Qnode*,ci∈int),i=1,2...,n,n≥0};数据关系:R=∅基本操作:Car_enter(carnum,cartime)/

11、/将到达车辆a的信息入栈s或者入队qCar_Leave(carnum,cartime);//将待离开车辆d出

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。