停车场模拟管理系统报告

上传人:好** 文档编号:101956048 上传时间:2019-09-30 格式:DOCX 页数:31 大小:375.70KB
返回 下载 相关 举报
停车场模拟管理系统报告_第1页
第1页 / 共31页
停车场模拟管理系统报告_第2页
第2页 / 共31页
停车场模拟管理系统报告_第3页
第3页 / 共31页
停车场模拟管理系统报告_第4页
第4页 / 共31页
停车场模拟管理系统报告_第5页
第5页 / 共31页
点击查看更多>>
资源描述

《停车场模拟管理系统报告》由会员分享,可在线阅读,更多相关《停车场模拟管理系统报告(31页珍藏版)》请在金锄头文库上搜索。

1、 实训报告专 业:班 级:学 号:姓 名:课设题目: 停车场模拟管理系统 指导教师:目录一、 需求分析1二、 总体设计12.1系统功能概述1三、 到达停车场准备进入停车场23.1进入停车场函数2四、 离开停车场3五、 详细设计55.1函数的调用关系55.2主要算法的流程图6六、 软件说明:76.1使用环境:Visual C+ 6.0.7操作要求:程序运行后,用户根据所要进行的操作选择是进入停车场还是离开停车场并输入车牌号和时间76.2测试图:7七、 总结9附录:程序代码91、 需求分析 停车场模拟管理系统现在很多的大型超市等都有智能的停车场当你进入停车场门口就会自动的显示里面还有多少的空位并且

2、指引你走到空的车位停下避免了把车辆开进去并且找不到空的车位和因为车子在停车场内乱走而导致想出来的车没有足够的时间出来。导致空间和时间各种不必要的麻烦所以急需我们做一个停车场管理系统 。我们的停车场模拟管理系统有以下方面功能:1记录进入停车场的车辆的车牌号从而进入后可以知道其所停的停车位。2车子离开停车场根据离开时间和进入时间从而计算出所需要交的费用。3如果队列已经满了可以让要进入停车场的车子停在旁边的等候队列。2、 总体设计2.1系统功能概述(1)如果选择进入停车场就要判断停车场是否已经满了,如果未满直接进入,如果满了的话就直接排在旁边的便道上等待有车子离开停车场从而进入停车场。(2) 同时改

3、程序还设立多了一个位置以便与有车进入同时有车离开可以停留在这里等候车子离开再进入。(以防止车子停车场内的车未能离开进入的车又正在进入从而导致停车场堵塞的情况)(3) 离开的时候根据离开的车牌号从而把它从停车场中的位置移开并且通过离开时间和进入停车场的时间来计算出该车子所需要交纳的费用。等候队列离开停车场退出 进入停车场系统操作界面 有车离开 如果等候队列不为空的话进入停 2.11 总体设计图3、 到达停车场准备进入停车场void parkingmanagement:arrival(carstack &cs,carqueue &cq,int cnum,double ctime)int pos;i

4、f(!(cs.full() 到达停车场的车子首先输入其判int fl(0),i; 断停车场是否已经满了如果则直for(i=0;i=cs.top;i+) 接进入等候车道否则就进入停场if(cs.si.number=cnum)fl=1;break;if(fl=1)cout输入错误!请重新输入!如果到达的车的车牌号!=栈内已有车辆的车牌号endl;elsepos=pushstack(cs,cnum,ctime);/入栈,返回车位信息cout该停车场还有空位,请到pos号车位进行泊车endl;coutendl;elsepos=pushqueue(cq,cnum,ctime);cout该停车场已满,请将

5、车停到便道pos号车位上endl;coutendl;3.1进入停车场函数 int parkingmanagement:pushstack(carstack &cs,int cnum,double ctime)if(cs.top=Max-1)cout停车场已满!endl;return Max;else cs.top+;(cs.scs.top).number=cnum;(cs.scs.top).time=ctime;return (cs.top+1); 4、 离开停车场void parkingmanagement:leave(carstack &cs,carqueue &cq,int cnum,d

6、ouble ctime)int i,flag(0),pstack,count(1),outcarnum;double hour;car *p;for(i=0;i=cs.top;i+)if(cs.si).number=cnum)flag=1;break;if(flag)popstack(cs,cnum);hour=ctime-popstacktime;outcarnum=popqueue(cq);/pstack=pushstack(cs,outcarnum,ctime);cout该车在本停车场内停留时间为hour分钟,应付金额hour*(price/60)元!next;if(p-number=c

7、num)deletequeue(cq,count);if(countMax)cout您的车在便道上的位置为count号车位,请自行驶离,无需付费!endl;break;if(p=NULL) cout您的车不在本停车场内,或输入有误,请重新输入!endl; 5、 详细设计5.1函数的调用关系 如下图:主函数 数据输入 进入停车场Pushtack函数 判断是进入还是离开Arrival或者leave函数 等候便道pos=pushqueue(cq,cnum,ctime); 有车离开则进入 判断停车场是否满 full() 满则进入等候队列 图5.11 函数调用5.2主要算法的流程图图5.22主要算法图6

8、、 软件说明:6.1使用环境:Visual C+ 6.0.操作要求:程序运行后,用户根据所要进行的操作选择是进入停车场还是离开停车场并输入车牌号和时间6.2测试图:程序开始运行: 图 6.1 程序主界面进入停车场输入选项和车牌号和时间:图6.2 进入停车场离开停车场输入D 车牌号 时间:(根据车牌号找到相应的车)图6.3离开停车场显示结果 7、 总结在这一次的实训中才知道什么叫做真真正正的体会到什么叫做你看得懂程序听得懂课拿着中上的成绩你就口可以说你懂数据结构懂C+懂C了,无数次在修改代码无数次在询问老师问题同学问题,每一次编译错误减少一小个心里乐得跟开了花似的。非常的感谢同学和老师在QQ上不

9、厌其烦的一次又一次的回答我的问题哪怕是一个马虎的分号的错误。正所谓勤能补拙往后的我要更加的努力去学习了。附录:程序代码#includeusing namespace std; const int Max=10;const double price=30;class carpublic:double time;int number;car *next;class carstack friend class parkingmanagement;public:carstack();int empty();int full();car *s;int top;carstack:carstack()top

10、=-1;s=new carMax;if(s=NULL)cout栈空间分配不成功!endl;exit(1);int carstack:full()return top=Max-1;class carqueuefriend class parkingmanagement;public:carqueue();int full();car *front,*rear;carqueue:carqueue()rear=front=NULL;class parkingmanagement public:int pushstack(carstack &cs,int cnum,double ctime);void

11、 popstack(carstack &cs,int cnum);int pushqueue(carqueue &cq,int cnum,double ctime);int popqueue(carqueue &cq);void arrival(carstack &cs,carqueue &cq,int cnum,double ctime);void leave(carstack &cs,carqueue &cq,int cnum,double ctime);void deletequeue(carqueue &cq,int i);int popstacknumber;double popst

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 事务文书

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号