收藏 分销(赏)

C语言-实验室设备管理系统.doc

上传人:二*** 文档编号:4540887 上传时间:2024-09-27 格式:DOC 页数:11 大小:71KB 下载积分:5 金币
下载 相关 举报
C语言-实验室设备管理系统.doc_第1页
第1页 / 共11页
本文档共11页,全文阅读请下载到手机保存,查看更方便
资源描述
- . C语言程序设计报告 1 课程设计题目:实验室设备管理里系统 实验设备信息包括:设备编号、设备种类〔如:微机 打印机 扫描仪 等等〕、设备名称、设备价格、设备购入日期、是否报废、报废日期等。试设计一实验设备信息管理系统,使之能提供以下功能: 〔1〕能够完成对设备的录入和修改 〔2〕对设备进展分类统计 〔3〕设备的查询 2 需求分析 实验室设备信息用文件存储,提供文件的输入输出操作;要能够完成设备的录入和修改,需要提供设备添加和修改操作;实现对设备进展分类统计,需要提供排序操作;实现对设备查询需要提供查找操作,设备的查询可根据设备编号 设备种类 设备购入日期 正常设备〔未报废的〕等多种方式查询;另外还要根据键盘式选择菜单以实现功能选择。 3总体设计与模块的划分整个系统可设计为实验设备信息输入模块 实验设备信息添加模块 实验设备信息修改模块 实验设备分类统计模块和实验设备查询模块。 录入设备信息 修改设备信息 查询设备信息 统计设备信息 报废设备信息 退出 设备管理系统设计 开场 主函数流程图: 显示一系列功能选择 输入n,判断m,是否0到5 N+ 据n值调用各功能模块函数 完毕 4 建立实验设备信息构造体 构造体成员包括设备编号 设备名称 部门编号 部门名称 设备价格 设备购置时间 是否报废 报废日期。 5应用程序功能详细说明 程序运行后进入管理系统,显示目录:录入设备信息,修改设备信息,查询设备信息,统计设备信息,报废设备信息,退出 录入设备信息 系统提示用户在原有的根底上录入新的设备信息。流程图如下: 开场 输入设备编号,并将指针指向最末尾 依次输入设备机构体内容,完成一条添加记录 提示一完成一条记录添加 完毕 (1) 修改记录 系统要求用户输入要修改的设备编号,这时系统会显示设备的具体信息,用户只需该设备新的信息按要求输入即可对信息进展修改。流程图如下: 开场 判断是否有资料可以统计分类 没有资料可以统计 跳出 输入要统计的分类序号 按输入序号调用各功能模块函数 完毕 (2) 显示记录 无记录退出,有记录者按要求输出。流程图如下: 开场 没有记录可以显示,跳出 有记录者按要求输出 完毕 (3) 统计分类 假设有资料可以统计,那么按要求分类统计输出。流程图如下: 开场 判断是否有资料可以统计分类 没有资料可以统计 跳出 输入要统计的分类序号 按输入序号调用各功能模块函数 完毕 (4) 查询记录 假设信息为空,那么不能查询。流程图如下: 开场 判断是否有资料为空 资料为空 跳出 输入要查询的分类序号 按输入序号调用各功能模块函数 完毕 (6)完毕语 通过本次c语言的程序设计,我不仅提高稳固了c语言的根底,也初学习了编写一个实用程序的流程,提高了动手操作能力,也提高了对编程的兴趣。我相信经过努力后,我的编程能力一定会得到提高。 源程序代码清单: void main() { Node *equip; FILE *fp; int flag; Node *p,*q; printf("\t\t\t\t设备管理系统\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显示记录\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;/*统计记录 */ case 5:chaxun(equip);break;/*查询记录*/ default: printf("\n>>>>>>>>>>提示:输入错误!\n"); break; } } } Struct shebei { char ID[10]; char name[15]; char kind[15]; char over[15]; char yesno[10]; char time[10]; char price[10]; } void Add(Node *equip) /*添加记录*/ { Node *p,*r,*s; char id[10]; /*先用于输入ID,也用于判断是否跳出循环 */ r=equip; s=equip->next; /*使s为第一个有用的结点 */ while(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.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; /*也是必需的.将r 又重设为新链的最后一个有用结点 */ } } void Modify(Node *equip)/*修改*/ { Node *p; char find[20]; if(!equip->next) { N 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否那么输入任意数再进展修改:"); 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); printf("请输入新设备是否报废(原来是 %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) { printf("\n>>>>>>>>>>提示:没有记录可以显示!\n"); return; } printf("\t\t\t\t显示结果\n"); printf("设备 设备名称 设备种类 报废日期 是否报废 购置时间 价格\n"); while(p) { printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",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=0; char find[20]; 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("设备 设备名称 设备种类 报废日期 是否报废 购置时间 价格\n"); printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",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(flag2>ha){printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",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条记录:************\n\n",find,flag2); } else {printf("\n按设备号%s统计的结果为0个\n\n",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%-10s%-10s%-10s\n",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(flag2>ha){printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",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条记录:***************\n\n",find,flag2); } else {printf("\n按设备名称%s统计分类的结果为0个\n\n",find);} } else if(sel==0) return; } (6) 查询模块 void chaxun(Node *equip)/*查询*/ { Node *p; int sel;int flag2=0,ha=0; char find[20]; 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("设备 设备名称 设备种类 报废日期 是否报废 购置时间 价格\n"); printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",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(flag2>ha){printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",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条记录:*****************\n\n",find,flag2); } else {printf("\n按设备号%s统计的结果为0个\n\n",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%-10s%-10s%-10s\n",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(flag2>ha){printf("\n%-10s%-10s%-10s%-10s%-10s%-10s%-10s\n",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条记录:********************\n\n",find,flag2); } else {printf("\n按设备名称%s查询 结果为0个\n\n",find);} } else if(sel==0) return; } - . 可修编.
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 通信科技 > 开发语言

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

关于我们      便捷服务       自信AI       AI导航        抽奖活动

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

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

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

关注我们 :微信公众号    抖音    微博    LOFTER 

客服