ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:108.61KB ,
资源ID:5304812      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5304812.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(C语言实验室设备管理系统.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

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

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

2、报废的)等多种方式查询;另外还要根据键盘式选择菜单以实现功能选择。 3总体设计与模块的划分 整个系统可设计为实验设备信息输入模块 实验设备信息添加模块 实验设备信息修改模块 实验设备分类统计模块和实验设备查询模块。 主函数流程图: N+ 4 建立实验设备信息结构体结构体成员包括设备编号 设备名称 部门编号 部门名称 设备价格 设备购买时间 是否报废 报废日期。5应用程序功能详细说明程序运行后进入管理系统,显示目录:录入设备信息,修改设备信息,查询设备信息,统计设备信息,报废设备信息,退出录入设备信息 系统提示用户在原有的基础上录入新的设备信息。流程图如下: (1) 修改记录 系统要求用户输入要

3、修改的设备编号,这时系统会显示设备的具体信息,用户只需该设备新的信息按要求输入即可对信息进行修改。流程图如下:(2) 显示记录 无记录退出,有记录者按要求输出。流程图如下:(3) 统计分类 若有资料可以统计,则按要求分类统计输出。流程图如下:(4) 查询记录 若信息为空,则不能查询。流程图如下:(6)结束语 通过本次c语言的程序设计,我不仅提高巩固了c语言的基础,也初学习了编写一个实用程序的流程,提高了动手操作能力,也提高了对编程的兴趣。我相信经过努力后,我的编程能力一定会得到提高。源程序代码清单:void main() Node *equip; FILE *fp; int flag; Nod

4、e *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); /*关闭文件*/ while(1) printf(*目录*); printf(n1添加记录n); printf(n

5、2修改记录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: Ton

6、gji(equip); break;/*统计记录 */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

7、-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请输入

8、设备种类:); 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; /*也是必需

9、的.将r 又重设为新链的最后一个有用结点 */ void 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(完成修改

10、请输入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.ove

11、r); 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;

12、p=equip-next; if(!p) printf(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

13、 *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(设备号

14、码 设备名称 设备种类 报废日期 是否报废 购买时间 价格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

15、.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(%s,find); while(p) if(strcmp(p-data.name,find)=0) flag2+; if(flag2=1&ha!=flag2) printf(设备号码 设备名称 设备种类 报废日期 是否报废 购买时间 价格n);

16、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

17、-next; if(flag2) 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; char find20;p=equip-next; if(!equip-next) /*若链表为空 */ printf(n提示:资料为空!n); return; printf(提示:n=0退出n=1按设备号

18、查询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%-10sn,p-data.ID,p-data.name,p-data.kind,p-data.over,p-data.yesno,p-dat

19、a.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=2)

20、 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%-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;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1