收藏 分销(赏)

实验设备管理系统设计—C语言课程设计.doc

上传人:天**** 文档编号:3529699 上传时间:2024-07-08 格式:DOC 页数:7 大小:43KB
下载 相关 举报
实验设备管理系统设计—C语言课程设计.doc_第1页
第1页 / 共7页
实验设备管理系统设计—C语言课程设计.doc_第2页
第2页 / 共7页
实验设备管理系统设计—C语言课程设计.doc_第3页
第3页 / 共7页
实验设备管理系统设计—C语言课程设计.doc_第4页
第4页 / 共7页
实验设备管理系统设计—C语言课程设计.doc_第5页
第5页 / 共7页
点击查看更多>>
资源描述

1、实验设备管理系统设计1. 题目与要求:1.1问题提出与要求:题目:实验设备管理系统设计要求:实验设备信息包括:设备编号,设备种类(如微机,打印机,扫描仪等),设备名称,设备价格,设备购入日期,是否报废,报废日期等。试设计一实验设备信息管理系统,使之能提供以下功能:(1)能够完成对设备的录入和修改。(2)对设备进行分类统计。(3)设备的查询2.功能实现设计:2.1总体设计:实验设备管理系统设计添加记录修改记录显示记录统计分类记录图1:系统功能模块图2.2详细设计: 1:主函数主函数设计要求简洁,只提供部分提示语和函数的调用【程序】开始显示一系列功能选项输入n,判断n是否是14?根据n的值调用各函

2、数模块结束n图2:主函数流程图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=NULL; p-next=q; p=q; /将该接点挂入链表中 fclose(fp); /关闭文件

3、 while(1) printf(*目录*); printf(n1添加记录n); printf(n2修改记录n); printf(n3显示记录n); printf(n4统计分类记录n); printf(n0*-EXIT-*n); printf(请输入你要操作的序号:); scanf(%d,&flag); switch(flag) case 0: printf(n提示:已经退出系统,ByeBye!n);break; case 1: Add(equip); break; /增加记录 case 2: Modify(equip); break;/修改记录 case 3: Disp(equip); br

4、eak;/显示记录信息 case 4: Tongji(equip); break;/统计记录 default: printf(n提示:输入错误!n); break; 一:以下为添加记录的程序:while(1) printf(提示:输入0则返回主菜单!n); printf(n请你输入设备ID号:); scanf(%s,id); if(strcmp(id,0)=0) break; p=(Node *)malloc(sizeof(Node); /申请空间 strcpy(p-data.ID,id); printf(n请输入设备名称:); scanf(%s,p-data.name); printf(n请

5、输入设备种类:); scanf(%s,p-data.kind); printf(n请输入报废日期:); scanf(%s,&p-data.over); printf(n请输入设备是否报废:); scanf(%s,&p-data.yesno); printf(n请输入设备购买时间:); scanf(%s,&p-data.time); printf(n请输入设备价格:); scanf(%s,&p-data.price); printf(提示:已经完成一条记录的添加。n); p-next=NULL; r-next=p; /这一步是必需的,将p与先前的链表连起来构成一条新链表 r=p; /也是必需的.

6、将r 又重设为新链的最后一个有用结点 二:以下为修改记录的程序:void Modify(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-data.ID,find)=0) /如果找到的话返回的是符合要求 break; p=p-next; if(p) /若找到 int x; while(1) printf(完成修改请输入0否则

7、输入任意数再进行修改:); scanf(%d,&x); if(x=0) break; printf(请输入新设备号(原来是 %s ):,p-data.ID); scanf(%s,p-data.ID); printf(请输入新设备名称(原来是 %s ):,p-data.name); scanf(%s,p-data.name); printf(请输入新设备设备种类名称(原来是 %s ):,p-data.kind); scanf(%s,p-data.kind); printf(请输入新设备报废日期名称(原来是 %s ):,p-data.over); scanf(%s,p-data.over); pr

8、intf(请输入新设备是否报废(原来是 %s ):,p-data.yesno); scanf(%s,p-data.yesno); printf(请输入新设备购买时间(原来是 %s ):,p-data.kind); scanf(%s,p-data.time); printf(请输入新设备价格(原来是 %s ):,p-data.price); scanf(%s,p-data.price); printf(n提示:该项记录资料已经成功修改!n); else printf(n提示:你要修改的信息不存在!n);三:以下为显示记录的程序:void Disp(Node *equip)/输出记录Node *p

9、;p=equip-next;if(!p) printf(n提示:没有记录可以显示!n); return; printf(tttt显示结果n); printf(设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n); while(p) printf(n%-13s%-11s%-7s%-14s%-8s%-11s%-5sn,p-data.ID,p-data.name,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price); p=p-next;四:以下为统计分类记录的程序:void Tongji(Node *equip)/

10、统计Node *p;int sel;int flag2=0,ha=0;char 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-data.ID,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备号 设

11、备名称 设备种类 报废日期 是否报废 购买时间 价格n); printf(n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn,p-data.ID,p-data.name,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price); ha=flag2; else if(flag2ha)printf(n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn,p-data.ID,p-data.name,p-data.kind,p-data.over,p-data.yesno,p-data.time,p

12、-data.price);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输入你要统计分类的设备名称:); scanf(%s,find); while(p) if(strcmp(p-data.name,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n); printf(n%

13、-13s%-11s%-7s%-10s%-13s%-10s%-5sn,p-data.ID,p-data.name,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price); ha=flag2; else if(flag2ha)printf(n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn,p-data.ID,p-data.name,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price);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;

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 学术论文 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服