2022年C语言-实验室设备管理系统.pdf

上传人:C****o 文档编号:12786337 上传时间:2022-04-26 格式:PDF 页数:11 大小:131.11KB
返回 下载 相关 举报
2022年C语言-实验室设备管理系统.pdf_第1页
第1页 / 共11页
2022年C语言-实验室设备管理系统.pdf_第2页
第2页 / 共11页
点击查看更多>>
资源描述

《2022年C语言-实验室设备管理系统.pdf》由会员分享,可在线阅读,更多相关《2022年C语言-实验室设备管理系统.pdf(11页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、C语言程序设计报告1 课程设计题目:实验室设备管理里系统实验设备信息包括:设备编号、设备种类(如:微机打印机扫描仪等等) 、设备名称、设备价格、设备购入日期、是否报废、报废日期等。试设计一实验设备信息管理系统,使之能提供以下功能:(1)能够完成对设备的录入和修改(2)对设备进行分类统计(3)设备的查询2 需求分析实验室设备信息用文件存储,提供文件的输入输出操作;要能够完成设备的录入和修改,需要提供设备添加和修改操作;实现对设备进行分类统计,需要提供排序操作;实现对设备查询需要提供查找操作,设备的查询可根据设备编号设备种类设备购入日期正常设备(未报废的)等多种方式查询;另外还要根据键盘式选择菜单

2、以实现功能选择。3 总体设计与模块的划分整个系统可设计为实验设备信息输入模块实验设备信息添加模块实验设备信息修改模块 实验设备分类统计模块和实验设备查询模块。实 验设 备信 息输 入模块实 验设 备信 息添 加模块实 验设 备信 息修 改模块实 验设 备分 内统 计模块实 验设 备查 询模块功 能选择实 验 设 备 管 理 系 统 设 计精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 1 页,共 11 页 - - - - - - - - - - 主函数流程图: N+4 建立实验设备信息结构体结构体成员包括

3、设备编号设备种类设备名称设备价格设备购入日期是否报废报废日期。5 应用程序功能详细说明程序运行后进入管理系统,显示目录:添加记录、修改记录、显示记录、分类统计、查询记录(1)添加记录系统提示用户在原有的基础上录入新的设备信息。流程图如下:开始输入 ID 号,并将指针指向最末尾依次输入设备机构体内容,完成一条添加记录提示一完成一条记录添加结束开始显示一系列功能选择输入 n, 判断 m ,是否 0 到 5据 n 值调用各功能模块函数结束精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 2 页,共 11 页 -

4、- - - - - - - - - (2)修改记录系统要求用户输入要修改的设备ID 号,这时系统会显示设备的具体信息,用户只需该设备新的信息按要求输入即可对信息进行修改。流程图如下:(3)显示记录无记录退出,有记录者按要求输出。流程图如下:开始判断是否有资料可以统计分类没有资料可以统计跳出输入要统计的分类序号按输入序号调用各功能模块函数结束开始没有记录可以显示,跳出有记录者按要求输出结束精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 3 页,共 11 页 - - - - - - - - - - (4)统计

5、分类若有资料可以统计,则按要求分类统计输出。流程图如下:(5)查询记录若信息为空,则不能查询。流程图如下:开始判断是否有资料为空资料为空跳出输入要查询的分类序号按输入序号调用各功能模块函数结束开始判断是否有资料可以统计分类没有资料可以统计跳出输入要统计的分类序号按输入序号调用各功能模块函数结束精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 4 页,共 11 页 - - - - - - - - - - (6) 结束语通过本次c 语言的程序设计,我不仅提高巩固了c 语言的基础,也初学习了编写一个实用程序的流程

6、,提高了动手操作能力,也提高了对编程的兴趣。我相信经过努力后,我的编程能力一定会得到提高。源程序代码清单:void main() Node *equip; FILE *fp; int flag; Node *p,*q; printf(tttt设备管理系统n); equip=(Node*)malloc(sizeof(Node); equip-next=NULL; p=equip; fp=fopen(设备管理系统,wb+); q=(Node*)malloc(sizeof(Node); if(fread(q,sizeof(Node),1,fp) /*将文件的内容放入接点中* / q-next=NUL

7、L; p-next=q; p=q; /*将该接点挂入链表中*/ fclose(fp); /*关闭文件 */ while(1) printf(*目录 *); printf(n1添加记录 n); printf(n2修改记录 n); printf(n3显示记录 n); printf(n4统计分类 n); printf(“ n5 查询记录n”);printf(n0*-EXIT-*n); printf(请输入你要操作的序号:); scanf(%d,&flag); switch(flag) case 0: printf(n提示 :已经退出系统,ByeBye!n);break; case 1: Add(eq

8、uip); break; /*增加记录 */ case 2: Modify(equip); break;/*修改记录 */ 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 5 页,共 11 页 - - - - - - - - - - case 3: Disp(equip); break;/*显示记录信息 */ case 4: Tongji(equip); break;/*统计记录 */case 5:chaxun(equip);break;/*查询记录 */default: printf(n提示: 输入错误

9、 !n); break; Struct shebei char ID10; char name15; char kind15; char over15; char yesno10; char time10; char price10; void Add(Node *equip) /*添加记录 */ Node *p,*r,*s; char id10; /*先用于输入ID, 也用于判断是否跳出循环 */r=equip; s=equip-next; /*使 s 为第一个有用的结点 */while(r-next!=NULL) /*这个循环的作用是使r 为最后一个有用的结点*/ r=r-next; /*

10、将指针置于最末尾 */while(1) printf(提示 : 输入 0 则返回主菜单 !n); printf(n请你输入设备ID 号:); scanf(%s,id); if(strcmp(id,0)=0) break; p=(Node *)malloc(sizeof(Node); /*申请空间 */strcpy(p-,id); printf(n请输入设备名称:); scanf(%s,p-; printf(n请输入设备种类:); scanf(%s,p-; printf(n请输入报废日期:); scanf(%s,&p-; printf(n请输入设备是否报废:); scanf(%s,&p-; pr

11、intf(n请输入设备购买时间:); scanf(%s,&p-; printf(n请输入设备价格:); scanf(%s,&p-; printf(提示 : 已经完成一条记录的添加。n); p-next=NULL; 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 6 页,共 11 页 - - - - - - - - - - r-next=p; /*这一步是必需的, 将 p 与先前的链表连起来构成一条新链表*/ r=p; /*也是必需的 . 将 r 又重设为新链的最后一个有用结点 */ void Modify

12、(Node *equip)/*修改 */ Node *p; char find20; if(!equip-next) printf(n提示 : 没有资料可以修改!n); return; printf(请输入要修改的设备ID 号:); scanf(%s,find); p=equip-next; while(p!=NULL) if(strcmp(p-,find)=0) /*如果找到的话返回的是符合要求*/ break; p=p-next; if(p) /*若找到 */ int x; while(1) printf(完成修改请输入0 否则输入任意数再进行修改:); scanf(%d,&x); if(

13、x=0) break; printf(请输入新设备号( 原来是 %s ):,p-; scanf(%s,p-; printf(请输入新设备名称( 原来是 %s ):,p-; scanf(%s,p-; printf(请输入新设备设备种类名称( 原来是 %s ):,p-; scanf(%s,p-; printf(请输入新设备报废日期名称( 原来是 %s ):,p-; scanf(%s,p-; printf(请输入新设备是否报废( 原来是 %s ):,p-; scanf(%s,p-; printf(请输入新设备购买时间( 原来是 %s ):,p-; N精品资料 - - - 欢迎下载 - - - - -

14、 - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 7 页,共 11 页 - - - - - - - - - - scanf(%s,p-; printf(请输入新设备价格( 原来是 %s ):,p-; scanf(%s,p-; printf(n提示 : 该项记录资料已经成功修改!n); else printf(n提示 : 你要修改的信息不存在!n); void Disp(Node *equip)/*输出记录 */ Node *p; p=equip-next; if(!p) printf(n提示 : 没有记录可以显示!n); return; printf(tt

15、tt显示结果 n); printf(设备号码设备名称设备种类报废日期是否报废购买时间价格n); while(p) printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-; p=p-next; void Tongji(Node *equip)/*统计 */ Node *p; int sel;int flag2=0,ha=0; char find20;p=equip-next; if(!equip-next) /*若链表为空 */ printf(n提示 : 没有资料可以统计分类!n); return; printf(提示

16、:n=0 退出 n=1 按设备号统计 n=2 按设备名称统计n); scanf(%d,&sel); if(sel=1) printf(n输入你要统计分类的设备号:); scanf(%s,find); 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 8 页,共 11 页 - - - - - - - - - - while(p) if(strcmp(p-,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备号码设备名称设备种类报废日期是否报废购买时间价格 n); p

17、rintf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-; ha=flag2; else if(flag2ha)printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-;ha=flag2; p=p-next; if(flag2) printf(n*按设备号%s统计分类的有%d条记录:*nn,find,flag2); else printf(n按设备号 %s统计的结果为0 个nn,find); else if(sel=2) printf(n输入你要统计

18、分类的设备名称:); scanf(%s,find); while(p) if(strcmp(p-,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备号码设备名称设备种类报废日期是否报废购买时间价格 n); printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-; ha=flag2; else if(flag2ha)printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-;ha=flag2; p=p-n

19、ext; if(flag2) 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 9 页,共 11 页 - - - - - - - - - - printf(n*按设备名称%s统计的有%d条记录:*nn,find,flag2); else printf(n按设备名称 %s统计分类的结果为0 个nn,find); else if(sel=0) return; (6) 查询模块void chaxun(Node *equip)/*查询 */ Node *p; int sel;int flag2=0,ha=0; ch

20、ar find20;p=equip-next; if(!equip-next) /*若链表为空 */ printf(n提示 : 资料为空 !n); return; printf(提示 :n=0退出 n=1 按设备号查询n=2 按设备名称查询n); scanf(%d,&sel); if(sel=1) printf(n输入你要查询的设备号:); scanf(%s,find); while(p) if(strcmp(p-,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备号码设备名称设备种类报废日期是否报废购买时间价格 n); printf(n%-10s

21、%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-; ha=flag2; else if(flag2ha)printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-;ha=flag2; p=p-next; if(flag2) 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 10 页,共 11 页 - - - - - - - - - - printf(n*按设备号%s查询有%d条记录

22、:*nn,find,flag2); else printf(n按设备号 %s统计的结果为0 个nn,find); else if(sel=2) printf(n输入你要查询的设备名称:); scanf(%s,find); while(p) if(strcmp(p-,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备号码设备名称设备种类报废日期是否报废购买时间价格 n); printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-; ha=flag2; else if(flag2

23、ha)printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-,p-,p-,p-,p-,p-,p-;ha=flag2; p=p-next; if(flag2) printf(n*设备名称%s查询有%d条记录:*nn,find,flag2); else printf(n按设备名称 %s查询结果为 0 个nn,find); else if(sel=0) return; 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 11 页,共 11 页 - - - - - - - - - -

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

当前位置:首页 > 教育专区 > 高考资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁