




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上#include "stdio.h"#include "stdlib.h"#include "string.h"struct shebeichar ID10; char name15; char kind15; char over15; char yesno10; char time10; char price10; ;typedef struct nodestruct shebei data;struct node *next; /建立一个链表。Node;char find20; void Add(Node
2、 *equip) /添加记录Node *p,*r,*s; char id10; /先用于输入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&q
3、uot;,id); if(strcmp(id,"0")=0) break; p=(Node *)malloc(sizeof(Node); /申请空间 strcpy(p->data.ID,id); printf("n请输入设备名称:"); scanf("%s",p->); printf("n请输入设备种类:"); scanf("%s",p->data.kind); printf("n请输入报废日期:"); scanf("%s&quo
4、t;,&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(">>>>>>>&g
5、t;>>提示:已经完成一条记录的添加。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号
6、:"); 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->d
7、ata.ID); scanf("%s",p->data.ID); printf("请输入新设备名称(原来是 %s ):",p->); scanf("%s",p->); printf("请输入新设备设备种类名称(原来是 %s ):",p->data.kind); scanf("%s",p->data.kind); printf("请输入新设备报废日期名称(原来是 %s ):",p->data.over);
8、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(&q
9、uot;%s",p->data.price); printf("n>>>>>>>>>>提示:该项记录资料已经成功修改!n"); else printf("n>>>>>>>>>>提示:你要修改的信息不存在!n"); void Disp(Node *equip)/输出记录Node *p;p=equip->next;if(!p) printf("n>>>>>>>>
10、>>提示:没有记录可以显示!n"); return; printf("tttt显示结果n"); printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n"); while(p) printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price);
11、 p=p->next;void Tongji(Node *equip)/统计Node *p;int sel;int flag2=0,ha=0;p=equip->next; if(!equip->next) /若链表为空 printf("n>>>>>>>>>>提示:没有资料可以统计分类!n"); return;printf(">>>>>>>>>>提示:n=>0退出n=>1按设备号统计n=>2按设备名称统计n&qu
12、ot;);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%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p
13、->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price); ha=flag2; else if(flag2>ha)printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->d
14、ata.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->,find)=0) flag2+; if(flag2=1&&
15、;ha!=flag2) printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n"); printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price); ha=flag2; else if(flag2>ha)printf("n%-13s%-11s%-7s%-10s%-
16、13s%-10s%-5sn",p->data.ID,p->,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
17、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;
18、/将该接点挂入链表中 fclose(fp); /关闭文件 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>>>>>&
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 汽车融资租赁出借资金借款合同
- 成品油运输与物流信息化管理合同
- 餐厅餐饮文化传承与发展合作协议
- 城市环卫工人意外伤害赔偿合同范本
- 高端商场专业安保场务专员劳动合同范本
- 纺织品百货品牌加盟合作协议
- 车辆保险代理合同范本:全方位车辆保险代理服务协议
- 旅游景区场地租赁分成及运营管理合同
- 高科技环保装备厂房建造与环保技术研发合同
- 餐饮品牌形象设计与推广合同
- 2024年天津市南开区初中学业考查模拟地理试卷
- 第四届福建省水产技术推广职业技能竞赛-水生物病害防治员备赛题库(含答案)
- 数字供应链对营运资金周转效率的影响分析
- 轻型卒中临床诊疗中国专家共识要点(2024年)解读课件
- 2022联合国电子政务调查报告(中文版)
- 国家开放大学《管理英语4》期末机考题库
- DeepSeek在银行业务场景的应用
- 居家适老化改造指导手册(2025年版)
- 炊事员培训试题及答案
- 模板包清工合同协议
- 2025年安全月主题宣贯课件
评论
0/150
提交评论