版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 c语言课程设计报告 目录一、 题目要求,需求分析二、 总体设计思路与功能模块划分三、 程序设计四、 程序运行测试五、 总结前 言计算机科学技术的发展,不仅极大地促进了整个科学技术的发展,而且明显地加快了经济信息化和社会信息化的进程。因此,计算机教育在全国备受重视,计算机知识与能力已成为21世纪人才素质的基本要素之一。如今,高等教育的计算机教育发展十分迅速。十多年前,只有部分理工科专业开设计算机课程。今天,几乎所有高校的所有专业都开设了程度不同的计算机课程。人们已经认识到,计算机知识已成为当代知识分子知识结构中不可缺少的重要组成部分。而除了掌握计算机的基础知识和操作的基本能力外,掌握一门高级编
2、程语言,并可以熟练运用它,已成为当代大学生综合能力必要组成。计算机技术发展如此迅猛,计算机应用如此广泛,需要学习的东西愈来愈多,而我们的总学时是有限的。一般来说,计算机课程学习可以分为两部分:一部分是理论课程学习,一部分是上机应用实习。根据我们专业的性质和要求,则应侧重于上机操作运用。为此,学校特意在本学期最后安排了32个学时的上机实习。现将一星期的实习内容及结果分析分列如下:一、题目要求:27.停车场管理21、有一个两层的停车场,每层有6个车位,当第一层车停满后才允许使用第二层,(停车场可用一个二维数组实现,每个数组元素存放一个车牌号)每辆车的信息包括车牌号,层号,车位号,停车时间共4项,其
3、中停车时间按分钟计算。2、假设停车场初始状态为第一层已经停有4辆车,其车位号依次为14,停车时间依次为20,15,10,5。即先将这四辆车的信息存入文件“car.dat"中(数组的对应元素也要进行赋值)。3、停车操作:当一辆车进入停车场时,先输入其车牌号,再为它分配一个层号和一个车位号(分配前先查询车位的使用情况,如果第一层有空则必须停在第一层),停车时间设为5,最后将新停入的汽车的信息添加文件"car.dat"中,并将在此之前的所有车的停车时间加5。4、收费管理(取车):当有车离开时,输入其车牌号,先按其停车时间计算费用,每5分钟0.2元。(停车费用可设置一个变
4、量进行保存),同时从文件"car.dat"中删除该车的信息,并将该车对应的车位设置为可使用状态(即二维数组对应元素清零)。按用户的选择来判断是否要输出停车收费的总计。5、输出停车场中全部车辆的信息。6、退出系统。需求分析:车辆信息用文件储存,提供文件的输入输出操作;当车离开时要删除文件中该车的信息,因而要提供文件的删除操作;另外还要用键盘式菜单实现功能选择。二、总体设计思路:整个管理系统设计可设计为停车模块、取车模块、车辆浏览信息模块。另外车辆停放信息涉及到从car.dat中读取,保存和修改,为了方便起见,和程序的模块化,我们将文件的读入和保存单独设计为两个子程序。输入车辆
5、车牌号存车 putcar停车模块saveall将车辆信息存入car.dat输入车牌号码取车getcar取车模块删除车辆信息显示停车费用main键盘式菜单showinfo车位信息exit退出 图1 整体模块图各子程序设计如下:1.使用全局变量数组,用一个二维数组实现停车场车位的信息, int cars124;2.通过读取car.dat的数据,对程序初始化。下图为car.dat的初始数据:在init()通过一个for循环完成对car.dat中数据的读取。for(i=0;i<12;i+) fscanf(fp,"%d ", &carsi0); fscanf(fp,&q
6、uot;%d ", &carsi1); fscanf(fp,"%d ", &carsi2); fscanf(fp,"%d ", &carsi3); 3.同理,我们设计一个子程序saveall()用来保存停车场车位的信息到car.dat。用for循环再将处理后的数据存入文件中。for(i=0;i<12;i+) fprintf(fp,"%d ", carsi0);fprintf(fp,"%d ", carsi1);fprintf(fp,"%d ", carsi
7、2);fprintf(fp,"%d ", carsi3);fprintf(fp,"n" );4.进行对停车模块的设计:首先,输入车辆的车牌号,我们从键盘读取车牌号码,并判断车牌号码是否正确(五位数整型车牌号码)。输入出错时要求继续输入。我们引入flag标志量判断车牌号是否正确,初始int flag=1,从键盘读入车牌号码,并判断:printf("请输入您的车牌号:");doscanf("%d",&temp);if(temp>9999)&&(temp<100000)break;fl
8、ag=0;printf("请重新输入五位数车牌号n :");while(!flag);其次,读取的车牌号正确之后对标志量清零flag=0,代表没有没有找到车位,进行为车辆找停车位的操作,如下:flag=0; for(i=1;i<13;i+) if(carsi0!=0)continue; carsi0=temp; flag=1; break; 通过for循环和continue语句找到没有停车的车位,即cari0不等于0,并将标志量flag赋值1,表示有车位,用break语句跳出循环。再用if语句处理flag=1的情况,即停车场车位已满无法停车。最后,对存入的车辆赋初始时
9、间5,并且前面的已存入的车辆时间都加5。语句如下:for(i=0;i<12;i+) if(carsi0!=0)carsi3+=5;carsi2+=i;又因为我在car.dat已经对车辆的停放楼层和车位有过初始赋值,可以省去再对carsi1和carsi2的操作。并且可以满足“第一层有空位必须停在第一层”的要求,不过存在一个问题就是车辆只能按车位序号停放。5、取车模块:第一步,读取要提取车辆的车牌号码。再通过flag标志量对所输入车牌号正误分别处理。(初始flag=0)第二步,对于输入正确的车辆进行操作:删除车辆信息,再计算费用,再对时间清零并标志取车成功。第三步,进过上一步后取车不成功时即
10、flag还是为0时,提示重复输入车牌号直道成功为止。程序如下:doscanf("%d",&temp);if(temp>9999)&&(temp<100000)for(i=0;i<12;i+)if(carsi0=temp)carsi0=0; cost=0.2*carsi3/5;carsi3=0;flag=1;break;if(flag=0)printf("您输入的车牌号码有误,请重新输入。n");while(!flag);第四步,有选择性的显示收费价格:printf("n 显示停车费用?是(1)/否(2)
11、");scanf("%d",&i);switch(i)case 1:printf("n车牌号 : %d 费用 %8.2f元n",temp,cost);case 2:default: break;最后,调用saveall()函数来保存数据到car.dat。6、车辆信息浏览模块:注意我们只需要显示有车的车位可以用for循环语句再加上if判断语句来实现显示功能。printf("车牌号tt楼层t 车位 tt时间n");for(i=0;i<12;i+)if(carsi0!=0)printf("%dtt %d t
12、t%d tt %dn",carsi0,carsi1,carsi2,carsi3);7、主函数:调用子函数init()初始化读取car.dat文件。用printf在屏幕上显示停车场的菜单。再用switch语句实现选择执行哪个模块语句。switch(a) case 1:putcar(); break;case 2:getcar();break;case 3:showinfo();break;case 4:exit(0); break; default:printf("您输入的信息有误!n"); break;getchar();三、程序设计#include <st
13、dio.h>#include <stdlib.h>#include<conio.h>#include<io.h>int cars124; /*停车场使用数组*/void init() /*初始化*/char filename = "car.dat"file *fp;int i;if(fp = fopen(filename,"r") = null)printf("无法打开文件 " car.dat"n");return ;for(i=0;i<12;i+) /*读数据文件内
14、容到数组*/fscanf(fp,"%d ", &carsi0);fscanf(fp,"%d ", &carsi1);fscanf(fp,"%d ", &carsi2);fscanf(fp,"%d ", &carsi3);fclose(fp);void saveall() /*保存数据到car.dat*/char filename = "car.dat"file *fp;int i=0;if(fp = fopen(filename,"w") =
15、null)printf("无法打开文件 " car.dat"n");return ;for(i=0;i<12;i+) /*写数据到文件*/fprintf(fp,"%d ", carsi0);fprintf(fp,"%d ", carsi1);fprintf(fp,"%d ", carsi2);fprintf(fp,"%d ", carsi3);fprintf(fp,"n" );fclose(fp);void putcar() /*停车操作*/int
16、i;int temp;int flag=1;printf("nn*欢迎来到地大停车场*n");printf("请输入你的车牌号:");doscanf("%d",&temp);if(temp>0)&&(temp<10000)break;flag=0;printf("your car number is a digit between 0 and 10000:");while(!flag);flag=0;for(i=0;i<12;i+)if(carsi0!=0)continue
17、;carsi0=temp;flag=1;break;if(flag=0) /*没有找到位置,停车场已满*/printf("很抱歉!车位已满:n");return ;for(i=0;i<12;i+) /*所有车的停车时间一起加5*/if(carsi0!=0)carsi3+=5;saveall();getchar();printf("存车成功!n按任意键回到主菜单.");void getcar() /*取车*/int i,temp,flag=0;float cost;printf("nn*从停车场取车*n ");printf(&qu
18、ot; 请输入你的车牌号码:");doscanf("%d",&temp);if(temp>0)&&(temp<10000)for(i=0;i<12;i+)if(carsi0=temp)carsi0=0; /*删除该车位车辆信息*/cost=0.2*carsi3/5;carsi3=0;flag=1;break;if(flag=0)printf("您输入的车牌号码有误,请重新输入。n");while(!flag);printf("n printf out the cost?yes(1)/no(2)
19、");scanf("%d",&i);switch(i)case 1:printf("n车牌号 : %d 费用 %8.2f元n",temp,cost);case 2:default: break;saveall(); /*保存数据*/getchar();printf("取车成功!n按任意键回到主菜单.");void showinfo() /*显示当前停车场信息*/int i;printf("nn*当前停车场车位信息*n");printf("车牌号tt楼层t 车位 tt时间n");for(i=0;i<12;i+)if(carsi0!=0)printf("%dtt %d tt%d tt %dn",carsi0,carsi1,carsi2,carsi3);getchar();printf("输入任意键返回主菜单.");int main()int a;init();do printf("nnn*n");printf("* 地大停车场管理系统 *n");printf("* 1.停车
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 思维导图在小学数学教学中的有效性应用
- 清新扁平风商业计划书
- 浅谈税务会计师在企业财务管理工作
- VR智能虚拟旅游合作协议
- 《竞业禁止协议》
- 中小学电采暖系统优化方案
- 餐饮行业服务员合同范本
- 智能家居产品售后服务方案
- 医疗机构员工调薪方案优化建议
- 个人讲师网络课程录制协议
- 运动前后的热身与放松活动
- 氢能与燃料电池-课件-第五章-制氢技术
- 2024年四川农信招聘笔试参考题库含答案解析
- 大学食堂原料物资猪肉采购 投标方案
- 光纤电缆安装指南
- 2023北京海淀区高二上学期期末语文试题及答案
- 河南省郑州市中原区2023-2024学年九年级上学期期中数学试卷(含解析)
- 高标准农田蓄水池施工方案
- 铁塔认证考试题库大全-3动环专业部分
- 药学职业生涯人物访谈
- 羟亚胺的Semipinacol重排反应与改进探究
评论
0/150
提交评论