1 / 97
文档名称:

停车场管理系统及课程设计报告.doc

格式:doc   大小:377KB   页数:97页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

停车场管理系统及课程设计报告.doc

上传人:业精于勤 2022/12/8 文件大小:377 KB

下载得到文件列表

停车场管理系统及课程设计报告.doc

文档介绍

文档介绍:该【停车场管理系统及课程设计报告 】是由【业精于勤】上传分享,文档一共【97】页,该文档可以免费在线阅读,需要了解更多关于【停车场管理系统及课程设计报告 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。课程设计
课程:
题目:停车场管理系统
专业:
班级:
姓名:
年9月6日
《数据构造》课程设计
停车场管理系统
课程设计目的
通过课程设计,加深对《数据构造》这一课程所学内容的进一步理解与巩固。
通过课程设计,加深对构造化设计思想的理解,能对系统功能进行分析,并设计合理的模块化构造。
通过课程设计,提高程序开发功能,能运用合理的控制流程编写清晰高效的程序。
通过课程设计,训练C程序调试能力,能将一种中小型各级组织系统联调通过。
通过课程设计,开发一种中小型系统,掌握系统研发全过程。
通话课程设计,培养分析问题、解决实际问题的能力。
二、课程设计内容
问题描述:
设有一种可以停放n辆汽车的狭长停车场,它只有一种大门可以供车辆进出。车辆按达到停车场时间的早晚依次从停车场最里面向大门口处停放(最先达到的第一辆车放在停车场的最里面)。如果停车场已放满n辆车,则后来的车辆只能在停车场大门外的便道上等待,一旦停车场内有车开走,则排以便道上的第一辆车就进入停车场。停车场内如有某辆车要开走,在它之后进入停车场的车都必须先退出停车场为它让路,待其开出停车场后,这些辆再依本来的顺序进场。每辆车在离开停车场时,都应根据它在停车场内停留的时间长短交费。如果停留在便道上的车未进停车场时,容许其拜别,不收停车费,并且仍然保持在便道上等待的车辆的顺序。编制一程序模拟该停车场的管理。
基本规定:
规定程序输出每辆车达到后的停车位置(停车场或便道上),以及某辆车离开停车场应交纳的费用和它在停车场内停留的时间。
实现提示:
汽车的模拟输入信息格式可以是:(达到/拜别,汽车牌照号码,达到/拜别的时刻)。例如,(‘A’,1,5)表达1号牌照车在5这个时刻达到,而(‘D’,5,20)表达5号牌照车在20这个时刻拜别。整个程序可以在输入信息为(‘E’,0,0)时结束。本题可用栈和队列来实现。
三、概要设计
1、设计思想
此停车场管理系统是在一种狭长的通道上的,并且只有一种大门可以供车辆进出,并且要实现停车场内某辆车要离开时,在它之后进入停车场的车都必须先退出停车场为它让路,待其开出停车场后,这些辆再依本来的顺序进场的功能,就可以设计两个堆栈,其中一种堆栈用来模拟停车场,另一种堆栈用来模拟临时停车场,该临时停车场用来寄存当有车辆离开时,本来停车场内为其让路的车辆。至于当停车场已满时,需要停放车辆的通道可以用一种链队列来实现。当停车场内开走一辆车时,通道上便有一辆车进入停车场,此时只需要变化通道上车辆结点的连接方式就可以了,使通道上第一辆车进入停车场这个堆栈,并且使通道上本来的第二辆车成为通道上的第一辆车,此时只需将模拟通道的链队列的头结点连到本来的第二辆车上就可以了。
2、实现措施
对于此停车场管理系统的实现,就是用两个堆栈来分别模拟停车场以及停车场内车辆为其他车辆让路时退出停车的临时停放地点。至于通道上车辆的停放则用一种链队列来实现,此时,通道上车辆的离开或者进入停车场只需变化此链队列上的结点而已。对于要对停车场内的车辆根据其停放时间收取相应的停车费用,可以记录下车辆进入以及离开停车场的时间,再用时间差乘以相应的单价并且打印出最后的费用就可以实现了。
3、重要模块
①此停车场管理系统,重要分为如下若干模块:
一方面定义用来模拟停车场的堆栈以及用来模拟通道的链队列为全局变量,然后编写主函数,在此主函数中实现对其他各个模块的调用。在主函数中一方面调用option()
函数,浮现欢迎顾客使用的主界面,然后提示顾客进入此停车场管理系统后,再浮现一种供顾客选择的界面,在顾客的选择过程中,程序又分别调用车辆的达到、车辆的离开、停车场内停放车辆的信息以及退出程序这四个函数模块。其中,在车辆的离开那个模块函数中又调用了打印离开车辆信息的函数,在停车场内停放车辆信息的那个模块函数中,又分别调用了显示停车场上车辆信息的函数以及显示便道上车辆信息的函数。最后,从调鼐的这四个函数中回到主函数结束整个程序的运营。
②在以上各个模块中,浮现的调用的函数为:
voidInitStack(SeqStackCar*s);
intInitQueue(LinkQueueCar*Q);
option();
intArrival(SeqStackCar*Enter,LinkQueueCar*W);
voidLeave(SeqStackCar*Enter,SeqStackCar*Temp,LinkQueueCar*W);
voidPRINT(CarNode*p);
voidList(SeqStackCarS,LinkQueueCarW);
voidList1(SeqStackCar*S);
voidList2(LinkQueueCar*W);
4、模块间关系
开始
初始化两个栈Enter和Temp及一种队列Wait。
进入主菜单
车达到
车离开
退出
Room前车辆进临时栈
对room计费
便道车信息
车场内信息
判便道与否有车
车场与否为空
列表显示
栈Enter元素出栈
队列中元素进栈
队列Wait中元素出队
元素进栈Enter
便道车进车场
元素进队列Wait
判断栈与否为满
结束
退出列表显示






四、调试分析
(1)调试过程中的重要问题
由于此停车场管理系统是分模块设计的,并且在程序的实现过程中又使用了清屏函数,因此,运营时顾客选择任务并且执行完任务后,又会回到供顾客选择功能的主界面,因此整个程序从整体上来讲构造清晰,使用以便。本程序的调试运营,总体上状况良好,但中间也浮现了某些小问题。其中比较有代表性的重要问题有:
当停车场已经达到最大容量,但仍有车辆进入停车场的时候,运营界面上没有浮现或者说浮现了但又跳掉了“停车场已满,该车辆需在便道上等待!”的提示信息。我们小构成员通过反复商量讨论,并且在查阅了多种资料后,在那一种printf语句后加了一种getch(),此时,程序运营成果就符合规定了。
本程序中我使用的是VC6++进行的编译和运营!
(2)测试成果的分析与讨论
①欢迎界面
②车辆达到
③车辆离开
④车辆信息(车场)

最近更新