《C语言-实验室设备管理系统.doc》由会员分享,可在线阅读,更多相关《C语言-实验室设备管理系统.doc(11页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、- .C语言程序设计报告 1 课程设计题目:实验室设备管理里系统实验设备信息包括:设备编号、设备种类如:微机 打印机 扫描仪 等等、设备名称、设备价格、设备购入日期、是否报废、报废日期等。试设计一实验设备信息管理系统,使之能提供以下功能: 1能够完成对设备的录入和修改 2对设备进展分类统计 3设备的查询 2 需求分析 实验室设备信息用文件存储,提供文件的输入输出操作;要能够完成设备的录入和修改,需要提供设备添加和修改操作;实现对设备进展分类统计,需要提供排序操作;实现对设备查询需要提供查找操作,设备的查询可根据设备编号 设备种类 设备购入日期 正常设备未报废的等多种方式查询;另外还要根据键盘式
2、选择菜单以实现功能选择。 3总体设计与模块的划分整个系统可设计为实验设备信息输入模块 实验设备信息添加模块 实验设备信息修改模块 实验设备分类统计模块和实验设备查询模块。 录入设备信息修改设备信息查询设备信息统计设备信息报废设备信息退出设备管理系统设计开场主函数流程图:显示一系列功能选择输入n,判断m,是否0到5 N+据n值调用各功能模块函数完毕4 建立实验设备信息构造体构造体成员包括设备编号 设备名称 部门编号 部门名称 设备价格 设备购置时间 是否报废 报废日期。5应用程序功能详细说明程序运行后进入管理系统,显示目录:录入设备信息,修改设备信息,查询设备信息,统计设备信息,报废设备信息,退
3、出录入设备信息 系统提示用户在原有的根底上录入新的设备信息。流程图如下: 开场输入设备编号,并将指针指向最末尾依次输入设备机构体内容,完成一条添加记录提示一完成一条记录添加完毕(1) 修改记录 系统要求用户输入要修改的设备编号,这时系统会显示设备的具体信息,用户只需该设备新的信息按要求输入即可对信息进展修改。流程图如下:开场判断是否有资料可以统计分类没有资料可以统计 跳出输入要统计的分类序号按输入序号调用各功能模块函数完毕(2) 显示记录 无记录退出,有记录者按要求输出。流程图如下:开场没有记录可以显示,跳出有记录者按要求输出完毕(3) 统计分类 假设有资料可以统计,那么按要求分类统计输出。流
4、程图如下:开场判断是否有资料可以统计分类没有资料可以统计 跳出输入要统计的分类序号按输入序号调用各功能模块函数完毕(4) 查询记录 假设信息为空,那么不能查询。流程图如下:开场判断是否有资料为空资料为空 跳出输入要查询的分类序号按输入序号调用各功能模块函数完毕(6)完毕语 通过本次c语言的程序设计,我不仅提高稳固了c语言的根底,也初学习了编写一个实用程序的流程,提高了动手操作能力,也提高了对编程的兴趣。我相信经过努力后,我的编程能力一定会得到提高。源程序代码清单:void main() Node *equip; FILE *fp; int flag; Node *p,*q; printf(tt
5、tt设备管理系统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); /*关闭文件*/while(1) printf(*目录*); printf(n1添加记录n); printf(n2修改记录n); printf(n3显示记
6、录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(equip); break; /*增加记录*/case 2: Modify(equip); break;/*修改记录*/case 3: Disp(equip); break;/*显示记录信息*/case 4: Tongji(equip); break;/*统计记录
7、*/case 5:chaxun(equip);break;/*查询记录*/default: printf(n提示:输入错误!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为第一个有用的结点 */wh
8、ile(r-next!=NULL) /*这个循环的作用是使r为最后一个有用的结点*/r=r-next; /*将指针置于最末尾 */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请输入设备种类:); scanf(%s,p-data.k
9、ind); 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; /*也是必需的.将r 又重设为新链的最后一个有用结点 */ vo
10、id Modify(Node *equip)/*修改*/ Node *p; char find20; if(!equip-next) Nprintf(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否那么输入任意数再进展修改:); scanf
11、(%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); printf(请输入新设备是否报废(原来是
12、 %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; p=equip-next; if(!p) prin
13、tf(n提示:没有记录可以显示!n); return; printf(tttt显示结果n); printf(设备 设备名称 设备种类 报废日期 是否报废 购置时间 价格n); while(p) printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,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)/*统计*/ Node *p; int sel;int flag2=0,ha
14、=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(设备 设备名称 设备种类 报废日期 是否报废 购置时间 价
15、格n); printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,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%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-data.ID,p-data.name,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price);ha=flag2
16、; 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%-10s%-10s%-10s%-10s%-
17、10s%-10s%-10sn,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%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,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*按设备名
18、称%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; char find20;p=equip-next; if(!equip-next) /*假设链表为空 */ printf(n提示:资料为空!n); return; printf(提示:n=0退出n=1按设备号查询n=2按设备名称查询n); scanf(%d,&sel
19、); if(sel=1) printf(n输入你要查询的设备号:); scanf(%s,find); while(p) if(strcmp(p-data.ID,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备 设备名称 设备种类 报废日期 是否报废 购置时间 价格n); printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,p-data.ID,p-data.name,p-data.kind,p-data.over,p-data.yesno,p-data.time,p-data.price); ha=flag2;
20、 else if(flag2ha)printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,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=2) printf(n输入你要查询的设备名称:); scanf(%
21、s,find); while(p) if(strcmp(p-data.name,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备 设备名称 设备种类 报废日期 是否报废 购置时间 价格n); printf(n%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,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%-10s%-10s%-10s%-10s%-10s%-10s%-10sn,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; - . 可修编.
限制150内