- 1、本文档共16页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
PAGE
PAGE - 16 -
中国地质大学(武汉)
设计名称:
班级序号:
姓 名:
学 号:
指导老师:
C语言程序设计报告
前言
设计目的:通过设计一个停车场管理系统,进一步消化和巩固已学过的C 语言程序设计基础理论,学习和实践程序设计的各种技能,利用C 语言来设计各种应用程序和管理系统,为社会提供各种现代化的管理工具,同时也掌握与数组有关的算法、函数的调用、结构体类型变量的定义和使用;文件打开、关闭、读、写等文件操作函数的使用,提高实际运用能力。
设计内容
题目要求:27题:停车场管理2
内容:1. 有一个两层的停车场,每层有6个车位,当第一层车位停满后才允许使用第二层(停车场可用一个二维数组实现,每个数组元素存放一个车牌号)每辆车的信息包括车牌号,层号,车位号,停车时间共四项,其中停车时间按分钟计算。
2. 假设停车场初始状态为第一层已经有四辆车,其车位号依次为1-4,停车时间依次为20,15,10,5。即先将这四辆车的信息存入文件“car.dat”中(数组的对应元素也要进行赋值)
3. 停车操作:当一辆车进入停车场时,先输入其车牌号,再为它分配一个层号和一个车位号(分配前先查询车位的使用情况,如果第一层有空位则必须停在第一层),停车时间设为5,最后将新停入的汽车的信息添加文件“car.dat”中,并将在此之前的停车时间加5。(此题简化时间的处理:当有一辆车进入时才对别的车加时间5分钟)
4. 收费管理(取车):当有车开走时,输入其车牌号,先按其停车时间计算费用,每5分钟2毛钱。同时从文件“car.dat”k 删除该车的信息,并将该车对应的车位设置为可使用状态(即二维数组清零)。按用户的选择来判断是否要输出 停车收费的总计。
5. 输出 停车场中全部车辆的信息。
6. 退出系统。
需求分析
车辆信息要用文件存储,提供文件的输入输出操作;当车开走时要删除文件中该车的信息,因而要提供文件的删除操作;另外还要用键盘式菜单实现功能选择。
总体设计
整个管理系统可设计为停车模块、取车模块、车辆???息浏览模块。
停车场管理系统
停车模块
车辆信息浏览模块
取车模块
详细设计
首先定义包含与标准库有关的变量定义和宏定义和文件包含所用的文件
#include stdio.h
#include stdlib.h
#includeconio.h
#includeio.h
#include stdlib.h
然后用一个二维数组来表示一个停车场的位置,每个数组元素存放一个车牌号
int cars[12][4]={{1234,1,1,20},{2345,1,2,15},{3456,1,3,10},
{4567,1,4,5},{0,1,5,0},{0,1,6,0},{0,2,1,0},{0,2,2,0},{0,2,3,0},
{0,2,4,0},{0,2,5,0},{0,2,6,0}};/*二维数组代表停车信息*/
后定义一个文件夹来储存所停车的信息,开始有四辆车在车库
void save()
{FILE *fp;
int i,j;
if((fp=fopen(car.dat,w))==NULL)
{printf(cannot open file\n);
return;
}
for(i=0;i12;i++)
for(j=0;j4;j++)
if(fwrite(cars,2,1,fp)!=1)
printf(file write error\n);
fclose(fp);
getchar();
}
一.停车模块
开始
输入车牌号
车牌号在
1000至9999之间?
存入停车系统
结束
N
void car_park(void)/*停车操作*/
{int x,i,j;
printf(\n ^-^ 欢迎您的光临! ^-^\n );
printf( \n\n 请输入车牌号:\n\n);
车牌号要在1000至9999之间,输入错误的车牌号将返回主菜单
for (i=0;i12;i++)
if(cars[i][0]==x||x1000||x9999)break;
if(i!=12)
{printf(\n错误的号码或已经停过了 !!!\n);
getchar();}/*如果此车号以在,打印此车已停*/
else if(i==12x=1000x=9999)
{for (i=0;i12;i++)
if(cars[i][0]==0) {cars[i][0]=x;save();
printf(\n\n成功\n\n);
位置序号
层号
车 位
为车选择一个停车的
您可能关注的文档
最近下载
- SY_T 5660-2020 钻井液用包被絮凝剂 聚丙烯酰胺类.pdf VIP
- 2021-202x年基金管理人员工跟投基金投资协议-经典(律师审定版).docx
- 2010-2015年 中国电梯行业市场发展前景及投资分析报告.doc
- 78度智慧参考资料.pdf
- 基层儿科医务人员服务能力提升学习班答案-2024华医网继续教育答案.docx VIP
- DELTA台达伺服驱动器 ASDA-A2使用手册-操作说明书.pdf
- 国际贸易实务英文版(第五版)周瑞琪教材辅导习题解答.pdf
- 基于高斯滤波和近似积分的电动车窗防夹算法.pdf
- Application for Export Transaction 离岸客户填写指南.doc VIP
- 2023年膨化食品行业市场需求分析报告及未来五至十年行业预测报告.docx
文档评论(0)