1、#include#include#includestruct bookint num;char bname50;char wname20;char press50;char sort50;int time;float price;struct book *next;struct book *creatbook(); /创建链表struct book *addbook(struct book *head); /添加图书int yanzheng(struct book *head,int m); /验证新添加的图书编码是否已存在void deletebook(struct book *head);
2、 /删除图书void fprint(struct book *head); /将链表写入文件struct book *load(); /从文件中读取信息并建成链表void print_book(struct book *head); /将链表信息输出void chaxun(struct book *head); /查询图书信息void num_chaxun(struct book *head); /按图书编号查询图书void wname_chaxun(struct book *head); /按作者名查询图书void sort_chaxun(struct book *head); /按类别查询
3、图书void time_chaxun(struct book *head); /按出版时间查询图书void bname_chaxun(struct book *head); /按图书名查询图书void xiugai(struct book *head); /修改图书信息void paixu(struct book *head); /对图书进行排序void num_paixu(struct book *head); /按图书编号排序void time_paixu(struct book *head); /按图书出版时间排序void price_paixu(struct book *head);
4、/按图书价格排序void bname_paixu(struct book *head); /按图书名排序void wname_paixu(struct book *head); /按作者名排序int main()int choice,n,x,y=1,c,c1=1234;char a,d,b10,b110=“yjk“;struct book *head=NULL;while(y)system(“cls“);printf(“nnnnnnn“);printf(“ * 欢迎光临 *nn“);printf(“ * 图书信息管理系统 *nnn“);printf(“nn“);printf(“ =1-用户登录
5、=n“);printf(“ =0-退出系统=n“);printf(“ 请输入您的选择:“);scanf(“%d“,printf(“n“);getchar();switch(n)case 0:y=0;break;case 1:printf(“ 请输入您的用户名:“);gets(b);printf(“n“);printf(“ 请输入您的密码:“);scanf(“%d“,printf(“n“);if(strcmp(b,b1)!=0|c!=c1)printf(“ 验证失败,请重新输入!n“);scanf(“%c“,getchar();system(“cls“); elseprintf(“ 验证通过!请
6、按 Enter 键进入!n“);scanf(“%c“,getchar();x=1;while(x)system(“cls“);printf(“ -n“);printf(“ *图书信息管理系统*n“);printf(“ -nn“);printf(“ *nn“);printf(“ *nn“);printf(“ | 1-添加图书 2-删除图书 |nn“);printf(“ | 3-图书列表 4-图书排序 |nn“);printf(“ | 5-查询图书 6-修改图书 |nn“);printf(“ | 7-录入数据 0-退出系统 |nn“); printf(“ *nn“);printf(“ *nn“);
7、printf(“请输入所选择的序号:“);scanf(“%d“,getchar();system(“cls“);switch(choice)case 0:x=0;break;case 1:head=load();if(head=NULL)printf(“文件为空,请先录入数据!n“);getchar();break;elsehead=addbook(head);printf(“添加成功!n“);printf(“是否将新信息保存到文件?(y/n)n“);scanf(“%c“,getchar();switch(a)case n:break;case y:fprint(head);printf(“保
8、存成功!n“);getchar();break;break;case 2:head=load();if(head=NULL)printf(“文件为空,请先录入数据!n“);getchar();break;elsedeletebook(head);getchar();break;break;case 3:head=load();if(head=NULL)printf(“文件为空,请先录入数据!n“);getchar();break;elseprint_book(head);getchar();break;case 4:head=load();if(head=NULL)printf(“文件为空,请
9、先录入数据!n“);getchar();break;elsepaixu(head);getchar();break;case 5:head=load();if(head=NULL)printf(“文件为空,请先录入数据!n“);getchar();break;elsechaxun(head);getchar();break;case 6:head=load();if(head=NULL)printf(“文件为空,请先录入数据!n“);getchar();break;elsexiugai(head);getchar();break;break;case 7:printf(“注意: 输入图书编码为
10、 0 时结束 !n“);head=creatbook();printf(“是否将输入的信息保存到文件以覆盖文件中已存在的信息?(y/n)n“);getchar();scanf(“%c“,getchar();switch(a)case n:break;case y:fprint(head);printf(“保存成功!n“);getchar();break;break;default:printf(“您的输入有误,请重新输入!n“);getchar();break;break;default:printf(“ 您的输入有误! 请重新输入!n“);getchar();break;/录入数据并形成链表
11、struct book *creatbook()struct book *head,*tail,*p;int num,time,n;char bname50,wname20,press50,sort50;float price;int size=sizeof(struct book);head=tail=NULL;printf(“请输入图书编号:“);scanf(“%d“,printf(“请输入图书名:“);scanf(“%s“,bname);getchar();printf(“请输入作者名:“);scanf(“%s“,wname);getchar();printf(“请输入出版社:“);sc
12、anf(“%s“,press);getchar();printf(“请输入类别:“);scanf(“%s“,sort);getchar();printf(“请输入出版时间:“);scanf(“%d“,getchar();printf(“请输入价格:“);scanf(“%f“,getchar();while(1)p=(struct book *)malloc(size);p-num=num;strcpy(p-bname,bname);strcpy(p-wname,wname);strcpy(p-press,press);strcpy(p-sort,sort);p-time=time;p-pric
13、e=price;p-next=NULL;if(head=NULL)head=p;elsetail-next=p;tail=p;doprintf(“请输入图书编号:“);scanf(“%d“,n=yanzheng(head,num);if(n=0)break;elseprintf(“您输入的编号已存在,请重新输入!n“);while(1);if(num=0)break;else printf(“请输入图书名:“);scanf(“%s“,bname);getchar();printf(“请输入作者名:“);scanf(“%s“,wname);getchar();printf(“请输入出版社:“);
14、scanf(“%s“,press);getchar();printf(“请输入类别:“);scanf(“%s“,sort);getchar();printf(“请输入出版时间:“);scanf(“%d“,getchar();printf(“请输入价格:“);scanf(“%f“,getchar();return head;/插入结点,并且插入后仍按一定顺序struct book *addbook(struct book *head)struct book *ptr,*p1,*p2,*p;char bname50,wname20,press50,sort50;int size=sizeof(st
15、ruct book);int num,time,n=1;float price;doprintf(“请输入图书编号:“);scanf(“%d“,n=yanzheng(head,num);if(n=0)break;elseprintf(“您输入的编号已存在,请重新输入!n“);while(1);printf(“请输入图书名:“);scanf(“%s“,bname);getchar();printf(“请输入作者名:“);scanf(“%s“,wname);getchar();printf(“请输入出版社:“);scanf(“%s“,press);getchar();printf(“请输入类别:“
16、);scanf(“%s“,sort);getchar();printf(“请输入出版时间:“);scanf(“%d“,getchar();printf(“请输入价格:“);scanf(“%f“,getchar();p=(struct book *)malloc(size);p-num=num;strcpy(p-bname,bname);strcpy(p-wname,wname);strcpy(p-press,press);strcpy(p-sort,sort);p-time=time;p-price=price;p2=head;ptr=p;while(ptr-nump2-num)p2=p2-n
17、ext;if(ptr-numnum)if(head=p2)head=ptr;elsep1-next=ptr;p-next=p2;elsep2-next=ptr;p-next=NULL;return head;/验证添加的图书编号是否已存在int yanzheng(struct book *head,int m)struct book *p;p=head;while(p!=NULL)if(p-num=m)break;p=p-next;if(p=NULL)return 0;elsereturn 1;/将新链表写入文件中void fprint(struct book *head)FILE *fp;c
18、har ch=1;struct book *p1;if(fp=fopen(“f1.txt“,“w“)=NULL)printf(“File open error!n“);exit(0);fputc(ch,fp);for(p1=head;p1;p1=p1-next)fprintf(fp,“%d %s %s %s %s %d %fn“,p1-num,p1-bname,p1-wname,p1-press,p1-sort,p1-time,p1-price);fclose(fp);/从文件中读取图书信息struct book *load()FILE *fp;char ch;struct book *hea
19、d,*tail,*p1;head=tail=NULL;if(fp=fopen(“f1.txt“,“r“)=NULL)printf(“File open error!n“);exit(0);ch=fgetc(fp);if(ch=1)while(!feof(fp)p1=(struct book *)malloc(sizeof(struct book);fscanf(fp,“%d%s%s%s%s%d%fn“,if(head=NULL)head=p1;elsetail-next=p1;tail=p1;tail-next=NULL;fclose(fp);return head;elsereturn NU
20、LL;/将整个链表的信息输出void print_book(struct book *head)struct book *ptr;if(head=NULL)printf(“n 没有信息!n“);return;printf(“ 图书信息列表如下n“);printf(“ =n“);printf(“ 编号 图书名 作者名 出版社 类别 出版时间 价格n“);for(ptr=head;ptr;ptr=ptr-next)printf(“ %d %s %s %s %s %d %.2fn“,ptr-num,ptr-bname,ptr-wname,ptr-press,ptr-sort,ptr-time,ptr
21、-price);printf(“ =n“);/删除图书信息void deletebook(struct book *head)int a;char b,ch=1;struct book *p1,*p2;FILE *fp;printf(“请输入要删除的图书编号:“);scanf(“%d“,p1=head;if(p1-num=agetchar();scanf(“%c“,getchar();switch(b)case n:break;case y:if(fp=fopen(“f1.txt“,“w“)=NULL)printf(“File open error!n“);exit(0);fclose(fp)
22、;printf(“文件已清空!n“);elsewhile(p1-num!=ap1=p1-next;if(p1-next=NULL)if(p1-num=a)p2-next=NULL;printf(“是否确定从文件中彻底删除该图书?(y/n)n“);getchar();scanf(“%c“,switch(b)case n:break;case y:fprint(head);printf(“删除成功!n“);getchar();break;elseprintf(“没有找到要删除的数据!n“);getchar();else if(p1=head)head=p1-next;printf(“是否确定从文件
23、中彻底删除该图书?(y/n)n“);getchar();scanf(“%c“,switch(b)case n:break;case y:fprint(head);printf(“删除成功!n“);getchar();break;elsep2-next=p1-next;printf(“是否确定从文件中彻底删除该图书?(y/n)n“);getchar();scanf(“%c“,switch(b)case n:break;case y:fprint(head);printf(“删除成功!n“);getchar();break;/图书查询void chaxun(struct book *head)in
24、t a;printf(“ =n“);printf(“ * 1-按图书编号查询 2-按图书名查询 *n“);printf(“ * 3-按图书类别查询 4-按作者名查询 *n“);printf(“ * 5-按出版时间查询 0-退出查询 *n“);printf(“ =n“);printf(“请输入所选择的编号:“);scanf(“%d“,getchar();switch(a)case 0:break;case 1:num_chaxun(head);break;case 2:bname_chaxun(head);break;case 3:sort_chaxun(head);break;case 4:w
25、name_chaxun(head);break;case 5:time_chaxun(head);break;default:printf(“您的输入有误!n“);break;/按编号查询图书信息void num_chaxun(struct book *head)int a;struct book *p; printf(“请选择您要查询的图书编号:“);scanf(“%d“,getchar();p=head;while(p!=NULL)if(p-num=a)break;p=p-next;if(p=NULL)printf(“没有找到该编号的图书!n“);elseprintf(“ 你所查询的图书信
26、息如下n“);printf(“ =n“);printf(“ * 编号 图书名 作者名 出版社 类别 出版时间 价格 *n“);printf(“ * %d %s %s %s %s %d %.2f *n“,p-num,p-bname,p-wname,p-press,p-sort,p-time,p-price);printf(“ =n“);/按图书名查询图书信息void bname_chaxun(struct book *head)char a50;int flag=0;struct book *p; printf(“请选择您要查询的图书名:“);gets(a);p=head;while(p!=NU
27、LL)if(strcmp(p-bname,a)=0)flag=1;break;p=p-next;if(flag=0)printf(“没有找到该图书名的图书!n“);elseprintf(“ 你所查询的图书信息如下n“);printf(“ =n“);printf(“ * 编号 图书名 作者名 出版社 类别 出版时间 价格 *n“);while(p!=NULL)if(strcmp(p-bname,a)=0)printf(“ * %d %s %s %s %s %d %.2f *n“,p-num,p-bname,p-wname,p-press,p-sort,p-time,p-price);p=p-ne
28、xt;printf(“ =n“);/按作者名查询图书信息void wname_chaxun(struct book *head)char a50;int flag=0;struct book *p; printf(“请选择您要查询的图书作者名:“);gets(a);p=head;while(p!=NULL)if(strcmp(p-wname,a)=0)flag=1;break;p=p-next;if(flag=0)printf(“没有找到该图书名的图书!n“);elseprintf(“ 你所查询的图书信息如下n“);printf(“ =n“);printf(“ * 编号 图书名 作者名 出版社
29、 类别 出版时间 价格 *n“);while(p!=NULL)if(strcmp(p-wname,a)=0)printf(“ * %d %s %s %s %s %d %.2f *n“,p-num,p-bname,p-wname,p-press,p-sort,p-time,p-price);flag=1;p=p-next;printf(“ =n“);/按图书类别查询图书信息void sort_chaxun(struct book *head)char a50;int flag=0;struct book *p; printf(“请选择您要查询的图书类别:“);gets(a);p=head;whi
30、le(p!=NULL)if(strcmp(p-sort,a)=0)flag=1;break;p=p-next;if(flag=0)printf(“没有找到该图书名的图书!n“);elseprintf(“ 你所查询的图书信息如下n“);printf(“ =n“);printf(“ * 编号 图书名 作者名 出版社 类别 出版时间 价格 *n“);while(p!=NULL)if(strcmp(p-sort,a)=0)printf(“ * %d %s %s %s %s %d %.2f *n“,p-num,p-bname,p-wname,p-press,p-sort,p-time,p-price);
31、flag=1;p=p-next;printf(“ =n“);/按图书出版时间查询图书信息void time_chaxun(struct book *head)int a,flag=0;struct book *p; printf(“请选择您要查询的图书出版时间:“);scanf(“%d“,getchar();p=head;while(p!=NULL)if(p-time=a)flag=1;break;p=p-next;if(flag=0)printf(“没有找到该图书名的图书!n“);elseprintf(“ 你所查询的图书信息如下n“);printf(“ =n“);printf(“ * 编号
32、图书名 作者名 出版社 类别 出版时间 价格 *n“);while(p!=NULL)if(p-time=a)printf(“ * %d %s %s %s %s %d %.2f *n“,p-num,p-bname,p-wname,p-press,p-sort,p-time,p-price);flag=1;p=p-next;printf(“ =n“);/修改图书信息void xiugai(struct book *head)int a,b;char c;struct book *p;printf(“请输入要修改的图书编号:“);scanf(“%d“,p=head;while(p!=NULL)if(
33、p-num=a)break;p=p-next;if(p=NULL)printf(“没有找到该编号的图书!n“);getchar();elseprintf(“ =n“);printf(“ * 1-编号 2-图书名 3-作者名 *n“);printf(“ * 4-出版社 5-类别 6-出版时间 *n“);printf(“ * 7-价格 8-修改全部 0-放弃修改 *n“);printf(“ =n“);printf(“请选择你要修改的信息编号:“);scanf(“%d“,getchar();switch(b)case 1:printf(“请输入新编号:“);scanf(“%d“,printf(“修改
34、成功!n“);getchar();break;case 2:printf(“请输入新图书名:“);gets(p-bname);printf(“修改成功!n“);break;case 3:printf(“请输入新作者名:“);gets(p-wname);printf(“修改成功!n“);break;case 4:printf(“请输入新出版社:“);gets(p-press);printf(“修改成功!n“);break;case 5:printf(“请输入新类别:“);gets(p-sort);printf(“修改成功!n“);break;case 6:printf(“请输入新出版时间:“);
35、scanf(“%d“,printf(“修改成功!n“);getchar();break;case 7:printf(“请输入新价格:“);scanf(“%f“,printf(“修改成功!n“);getchar();break;case 8:printf(“请输入新图书编号:“);scanf(“%d“,printf(“请输入新图书名:“);scanf(“%s“,p-bname);getchar();printf(“请输入新作者名:“);scanf(“%s“,p-wname);getchar();printf(“请输入新出版社:“);scanf(“%s“,p-press);getchar();pr
36、intf(“请输入新类别:“);scanf(“%s“,p-sort);getchar();printf(“请输入新出版时间:“);scanf(“%d“,getchar();printf(“请输入新价格:“);scanf(“%f“,getchar();printf(“修改成功!n“);getchar();break;case 0:break;default :printf(“您的输入有误!n“);break;printf(“是否将修改后的信息保存到文件中?(y/n)n“);scanf(“%c“,getchar();switch(c)case n:break;case y:fprint(head)
37、;printf(“保存成功!n“);getchar();break;/图书排序void paixu(struct book *head)int a;printf(“ =n“);printf(“ * 1-按图书编号排序 2-按出版时间排序 *n“);printf(“ * 3-按图书价格排序 4-按图书名排序 *n“);printf(“ * 5-按作者名排序 0-取消排序操作 *n“);printf(“ =n“);printf(“请输入您选择的编号:“);scanf(“%d“,getchar();switch(a)case 0:break;case 1:num_paixu(head);break;
38、case 2:time_paixu(head);break;case 3:price_paixu(head);break;case 4:bname_paixu(head);break;case 5:wname_paixu(head);break;default:printf(“您的输入有误!n“);break;/按图书编号排序void num_paixu(struct book *head)struct book *a1000,*p,*p1,*temp;int i,k,index,n=0;char b;p1=head;for(p=head;p;p=p-next)n+;for(i=0;inext
39、;for(k=0;knumnum)index=i;temp=aindex;aindex=ak;ak=temp;printf(“排序成功!n“);printf(“是否显示排序结果?(y/n)n“);scanf(“%s“,getchar();switch(b)case n:break;case y:printf(“ =n“);printf(“ * 编号 图书名 作者名 出版社 类别 出版时间 价格 *n“);for(i=0;inum,ai-bname,ai-wname,ai-press,ai-sort,ai-time,ai-price);printf(“ =n“);break;default:printf(“您的输入有误!n“);break;/按出版时间排序 void time_paixu(struct book *head)struct book *a1000,*p,*p1,*temp;int i,k,index,n=0;char b;p1=head;for(p=head;p;p=p-next)n+;for(i=0;inext;for(k=0;ktimetime)index=i;temp=aindex;aindex=ak;ak=temp;printf(“排序成功!n“);printf(“是否显示排序结