停车场管理系统软件工程课程设计样本.docx
- 文档编号:13467289
- 上传时间:2023-06-14
- 格式:DOCX
- 页数:24
- 大小:225.22KB
停车场管理系统软件工程课程设计样本.docx
《停车场管理系统软件工程课程设计样本.docx》由会员分享,可在线阅读,更多相关《停车场管理系统软件工程课程设计样本.docx(24页珍藏版)》请在冰点文库上搜索。
停车场管理系统软件工程课程设计样本
课程设计阐明书
课程名称:
_软件工程课程设计___
题目:
_停车场管理系统____
院系:
理学院
专业班级:
学号:
学生姓名:
指引教师:
__
年6月8日
安徽理工大学课程设计(论文)任务书
理学院院系信计教研室
学号
学生姓名
专业(班级)
设计题目
停车场管理系统
设
计
技
术
参
数
系统平台:
WindowsXP
开发工具:
MicrosoftVC++6.0
建模工具:
MicrosoftVisio
抓图工具:
红蜻蜓抓图精灵
设
计
要
求
运用软件工程思想和办法完毕停车场管理系统分析、设计、实现等,重要实现功能有:
记录车辆信息,动态分派车位,停车费用结算,查看停车场车位使用状况,退出系统等功能,解决车辆停放难,乱收费等问题。
工
作
量
需求分析,概要设计,详细设计,编码设计以及调试。
工
作
计
划
5月28日--5月30日完毕需求分析
6月1日--6月3日完毕概要设计和详细设计
6月4日--6月6日完毕程序设计
6月7日完毕Word文档编写及窗口截图
6月8日提交程序和课程设计阐明书
参
考
资
料
[1]严蔚敏.数据构造[M].北京:
清华大学出版社.
[2]齐志昌,谭庆平.软件工程[M].北京:
高等教诲出版社,.4
[3]谭浩强.C程序设计(第三版)[M]北京:
清华大学出版社.
[4]温秀梅.VisualC++面向对象程序设计[M]北京:
清华大学出版社,
[5]王珊,萨师煊.数据库系统概论[M].北京:
高等教诲出版社,.5
指引教师签字
教研室主任签字
5月28日
学生姓名:
学号:
专业班级:
课程设计题目:
停车场管理系统
指引教师评语:
成绩:
指引教师:
李涛
6月10日
安徽理工大学课程设计(论文)
第一章引言1
1.1系统制作背景1
1.2系统制作规定1
第二章需求分析1
2.1任务概述1
2.2系统开发因素1
2.3系统开发任务1
第三章概要构造设计2
3.1基本解决流程2
3.2总体构造3
4.2菜单函数4
4.3初始化模块设计
4.5车辆离开函数8
第五章测试分析10
5.1主菜单函数10
5.2初始化操作11
参照文献14
第一章引言
1.1系统制作背景
阐明:
使用此软件系统名称:
停车场管理系统
随着计算机技术发展,在各行各业应用越来越广泛,停车场管理由本来人工管理进入计算机系统管理那是个必然趋势,计算机系统管理可以大大提高管理效率和对的性。
1.2系统制作规定
设有一种可以停放n辆汽车狭长停车场,它只有一种大门可以供车辆进出。
车辆按到达停车场时间早晚依次从停车场最里面向大门口处停放(最先到达第一辆车放在停车场最里面)。
如果停车场已放满n辆车,则日后车辆只能在停车场大门外便道上等待,一旦停车场内有车开走,则排在便道上第一辆车就进入停车站。
停车站内如有某辆车要开走,在它之后进入停车场车都必要先退出停车站为它让路,待其开出停车场后,这些车辆再依本来顺序进场。
每辆车在离开停车场时,都应依照它在停车场内停留时间长短交费。
如果停留在便道上车未进停车场就要拜别,容许其拜别,不收停车费,并且依然保持在便道上等待车辆顺序。
编制一程序模仿该停车场管理。
第二章需求分析
2.1任务概述
依照题目规定,由于停车场是一种单条序列,可以用构造体实现;在程序中,需要懂得每辆来车详细停放位置,应提供提示、查找、标记工作。
车辆离开要计时计费。
此外,每天开始时,停车场要初始化。
2.2系统开发因素
随着经济发展和人民生活水平提高,买车成为人们奋斗目的之一,固然已有诸多人买起了车。
可是随着车辆增多,车辆停泊问题也随之浮现。
这就使得各停车场需要更加先进、更加完善车辆管理系统。
2.3系统开发任务
实现停车场当代化管理,记录车辆信息,动态分派车位,停车费用结算,查看停车场车位使用状况,退出系统等功能,解决车辆停放难,乱收费等问题。
第三章概要构造设计
3.1基本解决流程
车进入车场
不做任何计算
无点x
有
输入离开车辆离开时间,进行停车费用计算
此车背面车辆退出并进入暂时栈
车子离开
图3-1
3.2总体构造
图3-2
第四章详细构造设计
4.1程序系统构造
main()函数体内包括了界面选则某些menu(),并单独抽出来作为一种独立函数,目在于系统执行每某些模块后可以以便返回到系统界面。
即main()函数写为
如下:
voidmain()/*主函数*/
{
menu();/*菜单函数*/
}
图4-1
4.2菜单函数
voidmenu()
{
intn,w;
do
{
puts("\t\t**************MENU**************\n\n");
puts("\t\t\t1.初始化");
puts("\t\t\t2.有车进入");
puts("\t\t\t3.有车离开");
puts("\t\t\t4.退出");
puts("\n\n\t\t*********************************\n");
printf("Pleasechoiceyournumber(1-4):
[]\b\b");
scanf("%d",&n);
if(n<1||n>4)/*对选取数字作判断*/
{
w=1;
getchar();
}
elsew=0;
}while(w==1);
switch(n)
{
case1:
chushi();break;/*初始化函数*/
case2:
jinru();break;/*车辆进入函数*/
case3:
likai();break;/*车辆离开函数*/
case4:
exit(0);/*退出*/
}
}
4.3初始化模块设计
【需求分析】
该模块是将每一天开始停车场内和便道车位清零。
一方面建立场内场外构造体,构造体内成员即车位状态。
用循环实现车位致零即可。
structchangnei/*场内车道信息*/
{
intneikong;
}chn[N-1];
structchangwai/*场外车道信息*/
{
intwaikong;
}chw[M-1];
N和M分别是停车场和便道车位预设值,用宏定义。
顾客可依照实际状况变化。
#defineN100/*预设停车场有100个车位*/
#defineM100/*预设便道有100个出位*/
voidchushi()/*初始化函数*/
{
inti,j;
for(i=0;i<=N-1;i++)
chn[i].neikong=0;/*将场内车道设立为空*/
for(j=0;j<=M-1;j++)
chw[i].waikong=0;/*将便道车道设立为空*/
printf("\n\n\t\t已初始化\n\n");
menu();
}
函数出示化后将回到菜单界面。
4.4车辆进入函数
【需求分析】
车辆到达后,要指定车辆停车位置。
顾客依照菜单函数进入车辆进入模块。
按照每辆车到达顺序予以车辆顺序号,由0号开始。
车辆信息也建立构造体。
structcar/*车辆信息*/
{
intcar_num;/*车辆顺序号*/
intcar_arr;/*车辆到达时间*/
intcar_lef;/*车辆离开时间*/
intcar_stay;/*车辆停放位置*/
}car[CIXUHAO];
其中,CIXUHAO是车辆顺序号宏定义:
#defineCIXUHAO1000/*预设车辆顺序号。
不论车辆到达时停在场内或便道,均依次设立一种顺序号,由0开始*/
予以车辆顺序号之后,用循环判断停车场与否停满,再分别予以选取:
图4-2
voidjinru()/*车辆进入函数*/
{
inti,a;
inth=0;
printf("\n\n请输入该车顺序号(从0号开始):
");
scanf("%d",&a);
for(i=0;i { if(chn[i].neikong==0);/*无车标记0*/ if(chn[i].neikong==1)/*有车标记1*/ h=h+1; } if(h==N) printf("停车场内已停满,请停在便道上\n"); else { car[a].car_stay=h; chn[h].neikong=1; printf("该车应当停在停车场内第道%d(从0道开始记)\n",h); printf("请输入该车进停车场时刻(24小时整点计时): \n"); scanf("%d",&car[a].car_arr); } 便道上尚有车吗? menu(); } 程序执行完后回到菜单。 图4-3 4.5车辆离开函数 【需求分析】 若有一辆车要离开,则需要记录该车离开时间,以计算出该车在停车场内停车时间和应当缴纳费用。 该车离开后,要判断便道上与否有车等待进入,如有,则将便道上第一辆车停放在停车场内最后位置并记录好进场时间;若无,则返回菜单。 voidlikai()/*车辆离开函数*/ {inti,k,choi,time; doublefee; printf("请输入离开车辆顺序号[],并将此车之后车先所有退出停车场! "); scanf("%d",&i); printf("\n请输入离开车辆离开时刻(24小时整点计时): \n"); scanf("%d",&car[i].car_lef); fee=D*(car[i].car_lef-car[i].car_arr); time=car[i].car_lef-car[i].car_arr; printf("顺序号为%d车停车时间%d小时,应收费%f元\n",i,time,fee); printf("\n\n\n请让场内退出车再依次进场! \n\n\n"); printf("便道上当前有车吗? (请选取1或2)\n1.有\n2.没有\n");/*因便道上也许没有车,因而要做选取*/ scanf("%d",&choi); if(choi==2) { menu(); } if(choi==1) { printf("请让便道上第一辆车进场\n"); printf("该车顺序号为: \n"); scanf("%d",&k); printf("请输入该车进场时间: \n"); scanf("%d",&car[k].car_arr); menu(); } } D为预设停车场单位小时费用,用宏定义,便于后来修改。 #defineD1.2/*预设车辆停车费为1.2元每小时*/ 第五章测试分析 5.1主菜单函数 图5-1 5.2初始化操作 图5-2 5.3车辆进入 有车进入 图5-3 以上分别举例0,1,2三个车进场状况 5.4车辆离开并收费 图5-4 若便道上没车,则退回到主菜单 图5-5 若便道上有车 图5-6 第六章总结 一方面通过这次课程设计,加强了我动手和思考解决问题能力,学到了诸多课本上学不到知识,同步也巩固了对课本知识,对我将来也是有很大协助。 刚开始拿到这个题目是信心满满,但是在做过程中还是遇到了诸多问题。 在制作过程中心理虽然有诸多创意和构思,但是实际操作却存在很大困难。 制作界面时候学到最重要耐心,有恒心一切都会变得迎刃而解。 通过该实例实习,规定人们进一步理解和运用构造化程序设计思想和办法,初步掌握开发一种小型实用系统基本办法,学会调试较长程序,学会运用流程图表达算法,进一步掌握和提高运用C语言进行程序设计能力。 参照文献 [1]齐志昌,谭庆平.软件工程[M].北京: 高等教诲出版社,.4 [2]王珊,萨师煊.数据库系统概论[M].北京: 高等教诲出版社,.5 [3]王珊,萨师煊.数据库设计理论与实践[J].计算机应用与软件,1984.2 [4]刘浩,陈曜东.c#编程实例与技巧[M].北京: 清华大学出版社,.1 [5]何鹏飞,王征.C#实用编程百例[M].北京: 清华大学出版社,.3 7原程序代码 #include #include #include #defineN100/*预设停车场有100个车位*/ #defineM100/*预设便道有100个出位*/ #defineD1.2/*预设车辆停车费为1.2元每小时*/ #defineCIXUHAO1000/*预设车辆顺序号。 不论车辆到达时停在场内或便道,均依次设立一种顺序号,由0开始*/ voidmenu(); voidchushi(); voidjinru(); voidlikai(); structcar/*车辆信息*/ { intcar_num;/*车辆顺序号*/ intcar_arr;/*车辆到达时间*/ intcar_lef;/*车辆离开时间*/ intcar_stay;/*车辆停放位置*/ }car[CIXUHAO]; structchangnei/*场内车道信息*/ { intneikong; }chn[N-1]; structchangwai/*场外车道信息*/ { intwaikong; }chw[M-1]; voidmain()/*主函数*/ { menu();/*菜单函数*/ } voidmenu() { intn,w; do { puts("\t\t**************MENU**************\n\n"); puts("\t\t\t1.初始化"); puts("\t\t\t2.有车进入"); puts("\t\t\t3.有车离开"); puts("\t\t\t4.退出"); puts("\n\n\t\t*********************************\n"); printf("Pleasechoiceyournumber(1-4): []\b\b"); scanf("%d",&n); if(n<1||n>4)/*对选取数字作判断*/ { w=1; getchar(); } elsew=0; }while(w==1); switch(n) { case1: chushi();break;/*初始化函数*/ case2: jinru();break;/*车辆进入函数*/ case3: likai();break;/*车辆离开函数*/ case4: exit(0);/*退出*/ } } voidchushi()/*初始化函数*/ { inti,j; for(i=0;i<=N-1;i++) chn[i].neikong=0;/*将场内车道设立为空*/ for(j=0;j<=M-1;j++) chw[i].waikong=0;/*将便道车道设立为空*/ printf("\n\n\t\t已初始化\n\n"); menu(); } voidjinru()/*车辆进入函数*/ { inti,a; inth=0; printf("\n\n请输入该车顺序号(从0号开始): "); scanf("%d",&a); for(i=0;i { if(chn[i].neikong==0);/*无车标记0*/ if(chn[i].neikong==1)/*有车标记1*/ h=h+1; } if(h==N) printf("停车场内已停满,请停在便道上\n"); else { car[a].car_stay=h; chn[h].neikong=1; printf("该车应当停在停车场内第道%d(从0道开始记)\n",h); printf("请输入该车进停车场时刻(24小时整点计时): \n"); scanf("%d",&car[a].car_arr); } menu(); } voidlikai()/*车辆离开函数*/ {inti,k,choi,time; doublefee; printf("请输入离开车辆顺序号[],并将此车之后车先所有退出停车场! "); scanf("%d",&i); printf("\n请输入离开车辆离开时刻(24小时整点计时): \n"); scanf("%d",&car[i].car_lef); fee=D*(car[i].car_lef-car[i].car_arr); time=car[i].car_lef-car[i].car_arr; printf("顺序号为%d车停车时间%d小时,应收费%f元\n",i,time,fee); printf("\n\n\n请让场内退出车再依次进场! \n\n\n"); printf("便道上当前有车吗? (请选取1或2)\n1.有\n2.没有\n");/*因便道上也许没有车,因而要做选取*/ scanf("%d",&choi); if(choi==2) { menu(); } if(choi==1) { printf("请让便道上第一辆车进场\n"); printf("该车顺序号为: \n"); scanf("%d",&k); printf("请输入该车进场时间: \n"); scanf("%d",&car[k].car_arr); menu(); } }
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 停车场 管理 系统软件 工程 课程设计 样本