《2022年实验设备管理系统 .pdf》由会员分享,可在线阅读,更多相关《2022年实验设备管理系统 .pdf(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、#include stdio.h #include stdlib.h #include string.h struct shebei char ID10; char name15; char kind15; char over15; char yesno10; char time10; char price10; ; typedef struct node struct shebei data; struct node *next; /建立一个链表。Node; void Add(Node *equip) / 添加记录 Node *p,*r,*s; char id10; /先用于输入ID,也用于
2、判断是否跳出循环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.n
3、ame); 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); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 6 页 - - - - - - - - - printf
4、(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 find20; if(!equip-next) printf(n提示 :没有资料可以修改!n); return; printf( 请输入要修改的设备ID 号:); scanf(%s,find); p=equip-n
5、ext; 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( 请
6、输入新设备设备种类名称(原来是%s ):,p-data.kind); scanf(%s,p-data.kind); printf( 请输入新设备报废日期名称(原来是%s ):,p-data.over); scanf(%s,p-data.over); printf( 请输入新设备是否报废(原来是%s ):,p-data.yesno); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 6 页 - - - - - - - - - scanf(%s,p-data.yesno);
7、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(tttt显示结果 n
8、); printf( 设备号设备名称设备种类报废日期是否报废购买时间价格n); while(p) 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); p=p-next; void Tongji(Node *equip)/ 统计 Node *p; int sel;int flag2=0,ha=0; p=equip-next; char find20; if(!equip-next) /若链表为
9、空 printf(n提示 :没有资料可以统计分类!n); return; printf(提示 :n=0 退出 n=1 按设备号统计 n=2 按设备名称统计n); scanf(%d,&sel); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 6 页 - - - - - - - - - if(sel=1) printf(n 输入你要统计分类的设备号:); scanf(%s,find); while(p) if(strcmp(p-data.ID,find)=0) flag2+
10、; if(flag2=1&ha!=flag2) printf( 设备号设备名称设备种类报废日期是否报废购买时间价格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.
11、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(%s,find); while(p) if(strcmp(p-data.name,find)=0) flag2+; if(flag2=1&ha!=flag2) prin
12、tf( 设备号设备名称设备种类报废日期是否报废购买时间价格n); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 6 页 - - - - - - - - - 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)prin
13、tf(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; void main() Node *equip; FILE *fp; in
14、t 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); / 关闭文件while(1) printf(*目录*); printf(n1 添加记录 n); p
15、rintf(n2 修改记录 n); printf(n3 显示记录 n); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 6 页 - - - - - - - - - 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); break;/显示记录信息case 4: Tongji(equip); break;/统计记录default: printf(n提示 :输入错误 !n); break; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 6 页 - - - - - - - - -
限制150内