You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

254 lines
6.1 KiB

#include "stdio.h"
#include "stdlib.h"
#include "string.h"
struct shebei
{
char ID[10];
char name[15];
char kind[15];
char over[15];
char yesno[10];
char time[10];
char price[10];
};
typedef struct node
{
struct shebei data;
struct node *next; //建立一个链表。
}Node;
void Add(Node *machine) //添加记录
{
system("cls");
Node *p,*r,*s;
char id[10]; //先用于输入ID,也用于判断是否跳出循环
r=machine;
s=machine->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.yesno);
printf("\n请输入报废日期:");
scanf("%s",&p->data.over);
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 *machine)//修改
{
system("cls");
Node *p;
char find[20];
if(!machine->next)
{
printf("\n提示:没有资料可以修改!\n");
return;
}
printf("请输入要修改的设备ID号:");
scanf("%s",find);
p=machine->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.yesno);
scanf("%s",p->data.yesno);
printf("请输入新设备报废日期(原来是 %s ):",p->data.over);
scanf("%s",p->data.over);
printf("请输入新设备购买时间(原来是 %s ):",p->data.time);
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 *machine)//输出记录
{
system("cls");
Node *p;
p=machine->next;
if(!p)
{
printf("\n提示:没有记录可以显示!\n");
return;
}
printf("显示结果\n");
while(p)
{
printf("设备号%s\n",p->data.ID);
printf("设备名称%s\n",p->data.name);
printf("设备种类%s\n",p->data.kind);
printf("是否报废%s\n",p->data.yesno);
printf("报废日期%s\n",p->data.over);
printf("购买时间%s\n",p->data.time);
printf("购买价格%s\n",p->data.price);
p=p->next;
}
}
void Tongji(Node *machine)//统计
{
system("cls");
Node *p;
int sel;int flag2=0,ha=0;
p=machine->next;
char find[20];
if(!machine->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("设备号%s\n",p->data.ID);
printf("设备名称%s\n",p->data.name);
printf("设备种类%s\n",p->data.kind);
printf("是否报废%s\n",p->data.yesno);
printf("报废日期%s\n",p->data.over);
printf("购买时间%s\n",p->data.time);
printf("购买价格%s\n",p->data.price);
ha=flag2;
}
else if(flag2>ha){printf("设备号%s\n",p->data.ID);
printf("设备名称%s\n",p->data.name);
printf("设备种类%s\n",p->data.kind);
printf("是否报废%s\n",p->data.yesno);
printf("报废日期%s\n",p->data.over);
printf("购买时间%s\n",p->data.time);
printf("购买价格%s\n",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("设备号%s\n",p->data.ID);
printf("设备名称%s\n",p->data.name);
printf("设备种类%s\n",p->data.kind);
printf("是否报废%s\n",p->data.yesno);
printf("报废日期%s\n",p->data.over);
printf("购买时间%s\n",p->data.time);
printf("购买价格%s\n",p->data.price);
ha=flag2;
}
else if(flag2>ha){printf("设备号%s\n",p->data.ID);
printf("设备名称%s\n",p->data.name);
printf("设备种类%s\n",p->data.kind);
printf("是否报废%s\n",p->data.yesno);
printf("报废日期%s\n",p->data.over);
printf("购买时间%s\n",p->data.time);
printf("购买价格%s\n",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;
}
int main()
{
system("cls");
Node *machine;
FILE *fp;
int flag;
Node *p,*q;
printf("\n设备管理系统\n");
machine=(Node*)malloc(sizeof(Node));
machine->next=NULL;
p=machine;
fp=fopen("D:\\设备管理系统.txt","ab+");
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("\n********* 1添加记录 *********\n");
printf("\n********* 2修改记录 *********\n");
printf("\n********* 3显示记录 *********\n");
printf("\n********* 4统计分类记录 *********\n");
printf("\n********* 0 -EXIT- *********\n");
printf("\n********* 请输入你要操作的序号: *********\n");
scanf("%d",&flag);
switch(flag)
{
case 0: printf("\n>>>>>>>>>>提示:已经退出系统,ByeBye!\n");break;
case 1: Add(machine); break; //增加记录
case 2: Modify(machine); break;//修改记录
case 3: Disp(machine); break;//显示记录信息
case 4: Tongji(machine); break;//统计记录
default: printf("\n提示:输入错误!\n"); break;
}
}
}