c语言编程实验室设备系统(共6页)_第1页
c语言编程实验室设备系统(共6页)_第2页
c语言编程实验室设备系统(共6页)_第3页
c语言编程实验室设备系统(共6页)_第4页
c语言编程实验室设备系统(共6页)_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论