- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
停车场实验报告,停车场申请报告,停车场收费申请报告,停车场可行性报告,停车场可行性研究报告,立体停车场可行性报告,停车场管理报告,停车场可研报告,停车场调研报告,停车场报告
数据结构实验报告
——实验三 停车厂模拟管理程序的设计与实现
本实验的目的是进一步理解线性表的逻辑结构和存储结构,进一步提高使用理论知识指导解决实际问题的能力。
一、【问题描述】
设停车厂只有一个可停放几辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达的先后顺序依次排列,若车场内已停满几辆汽车,则后来的汽车只能在门外的便道上等候,一旦停车场内有车开走,则排在便道上的第一辆车即可进入;当停车场内某辆车要离开时,由于停车场是狭长的通道,在它之后开入的车辆必须先退出车场为它让路,待该车辆开出大门,为它让路的车辆再按原次序进入车场。在这里假设汽车不能从便道上开走,试设计这样一个停车厂模拟管理程序。为了以下描述的方便,停车厂的停车场用“停车位”进行叙述,停车厂的便道用“便道”进行叙述。
二、【数据结构设计】
1、为了便于区分每辆汽车并了解每辆车当前所处的位置,需要记录汽车的牌照号码和汽车的当前状态,所以为汽车定义一个新的类型CarNode,具体定义如下:
typedef struct node//车辆结点
{
char num[20];//车牌号码,定义为一个字符指针类型
}CarNode;
2、由于车位是一个狭长的通道,所以不允许两辆车同时出入停车位,当有车到来要进入停车位的时候也要顺次停放,当某辆车要离开时,比它后到的车要先暂时离开停车位,而且越后到的车就越先离开停车位,显然这和栈的“后进先出”特点相吻合,所以可以使用一个栈来描述停车位。
由于停车位只能停放有限的几辆车,而且为了便于停车厂的管理,为每个车位要分配一个固定的编号,不妨设为1、2、3、4、5(可利用数组的下标),分别表示停车位的1车位、2车位、3车位、4车位。5车位,针对这种情况使用一个顺序栈比较方便,具体定义如下:
typedef struct //停车场位用栈表示
{
CarNode *stack[Max+1]; //各个汽车的信息
int top; //指示栈顶位置
}StackCar;
3、当停车场的停车位上都已经停满了汽车,又有新的汽车到来时要把它调度到便道上,便道上的车辆要按照进入便道的先后顺序顺次存放在便道上,为便道上的每个位置也分配一个固定的编号,当有车从停车位上离开后,便道上的第一辆汽车就立即进入停车位上的某个车位,由于问题描述中限制了便道上的汽车不能从便道上开走,即便道上的汽车只有在停车位上停放过之后才能离开停车厂,这样越早进入便道的汽车就越早进入停车位,而且每次进入停车位的汽车都是处于便道“最前面”的汽车,显然,这和队列的先进先出特点相吻合,所以,这里使用一个顺序队来描述便道,可以利用数组的下标表示便道的位置,具体定义如下:
typedef struct car //便道上的车
{
CarNode *data;
struct car *next;
}QueueNode;
typedef struct Node
{
QueueNode *head;//设置头指针
QueueNode *rear;//设置为指针
}LinkQueueCar;
4、当某辆车要离开停车厂的时候,比它后进停车位的车要为它让路,而且当它开走之后让路的车还要按照原来的停放次序再次进入停车位的某个车位上,为了完成这项功能,再定义一个辅助栈,停车位中让路的车依次“压入”辅助栈,待提出开走请求的车开走后再从辅助栈的栈顶依次“弹出”到停车位中。辅助栈直接利用在2中定义的类型StackCar。
由于程序的各函数要对这些数据结构中的数据进行操作,而且每次操作的结果都要动态反应到以上数据结构中,所以在程序设计的时候使用以上新类型定义的变量都采用全局变量的形式。
三、【功能(函数)设计】
1、本程序从总体上分为六个大的功能模块:分别为:程序功能介绍和操作提示模块、汽车进入停车厂车位的管理模块、汽车离开停车厂车位的管理模块、查看某车辆状态的查询模块,查询停车场状态的模块和查询便道车辆状态的模块,具体功能描述如下:
1)程序功能介绍和操作提示模块:此模块给出程序欢迎信息,介绍本程序的功能,并给出程序功能所对应的键盘操作的提示,具体屏幕显示如下所示:
-------------欢迎进入停车场管理系统-------------
有车来时请按1
有车要走时请按2
查询某车辆信息请按3
查询停车场情况请按4
查询便道情况请按5
退出程序请按0
---------
您可能关注的文档
最近下载
- 普通话吟诵教程-徐健顺224页PPT.ppt VIP
- 2024中华传统文化知识竞赛试题(附答案) .docx VIP
- (2025秋新版)人教版八年级生物上册《第三节 神经系统支配下的运动》教案(教学设计).docx VIP
- 市政工程各个单位、分部分项等工程划分表(全套).pdf VIP
- 高层屋面工程施工方案.docx VIP
- DB43T 1299-2017 可调式防沉降检查井盖 .pdf VIP
- 人民币国际化问题研究的开题报告.pdf VIP
- 大金金制全效家用中央空调产品综合样本(1).pdf VIP
- 三会一课党建.ppt VIP
- 2025届高中英语一轮话题复习(教师版):主题一人与自我 语境3 健康的生活方式,积极的生活态度——饮食与健康.docx VIP
文档评论(0)