#include<stdio.h>
#include<stdlib.h>
struct Book
{
char title[128];
char author[40];
struct Book *next;
};
void printlibrary(struct Book *library)
{
struct Book *book;
int count=1;
book=library;
while(book!=NULL) // while
{
printf("book%d:",count);
printf("书名:%s\n",book->title);
printf("作者:%s\n",book->author);
book=book->next;
count++;
}
}
void getInput(struct Book *book)
{
printf("请输入书名:");
scanf("%s",book->title);
printf("请输入作者:");
scanf("%s",book->author);
}
void addBook(struct Book **library)
{
struct Book *book;
book=(struct Book *)malloc(sizeof(struct Book));
if(book==NULL)
{
printf("内存分配失败!");
exit(1);
}
getInput(book);
// 按你的思路这里使用的应该是 头插法
if(*library!=NULL)
{
book->next=*library;
*library = book;
}
else
{
*library=book;
book->next=NULL;
}
}
void releaselibrary(struct Book *library)
{
struct Book *temp;
while(library!=NULL)
{
// 释放顺序
temp = library->next;
free(library);
library=temp;
}
}
int main(void)
{
struct Book *library=NULL;
int ch;
while(1)
{
printf("是否需要录入书籍信息(Y/N):");
do
{
ch=getchar();
}while(ch!='Y'&&ch!='N');
if(ch=='Y')
{
addBook(&library);
}
else
{
break;
}
}
printf("是否需要打印书籍信息(Y/N):");
do
{
ch=getchar();
}while(ch!='Y'&&ch!='N');
if(ch=='Y')
{
printlibrary(library);
}
releaselibrary(library);
return 0;
}
|