用c语言单链表写一个图书管理系统
时间: 2023-11-25 17:06:55 浏览: 71
好的,下面是用单链表实现的图书管理系统的代码示例:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义图书结构体
typedef struct {
char name[50]; // 书名
char author[50]; // 作者
int count; // 库存数量
} Book;
// 定义节点结构体
typedef struct Node {
Book book; // 存储的图书信息
struct Node* next; // 指向下一个节点的指针
} Node;
// 添加图书
void addBook(Node* head) {
Node* p = head;
while (p->next != NULL) {
p = p->next;
}
Node* newNode = (Node*)malloc(sizeof(Node));
printf("请输入书名:");
scanf("%s", newNode->book.name);
printf("请输入作者:");
scanf("%s", newNode->book.author);
printf("请输入库存数量:");
scanf("%d", &newNode->book.count);
newNode->next = NULL;
p->next = newNode;
printf("图书信息添加成功!\n");
}
// 输出所有图书信息
void printAllBooks(Node* head) {
Node* p = head->next;
if (p == NULL) {
printf("链表为空!\n");
return;
}
printf("所有图书信息如下:\n");
printf("书名\t作者\t库存数量\n");
while (p != NULL) {
printf("%s\t%s\t%d\n", p->book.name, p->book.author, p->book.count);
p = p->next;
}
}
// 根据书名查找图书信息
void searchBookByName(Node* head) {
char name[50];
printf("请输入要查找的书名:");
scanf("%s", name);
Node* p = head->next;
while (p != NULL) {
if (strcmp(p->book.name, name) == 0) {
printf("书名\t作者\t库存数量\n");
printf("%s\t%s\t%d\n", p->book.name, p->book.author, p->book.count);
return;
}
p = p->next;
}
printf("未找到书名为%s的图书!\n", name);
}
// 删除指定图书信息
void deleteBook(Node* head) {
char name[50];
printf("请输入要删除的书名:");
scanf("%s", name);
Node* p = head->next;
Node* pre = head;
while (p != NULL) {
if (strcmp(p->book.name, name) == 0) {
pre->next = p->next;
free(p);
printf("已删除书名为%s的图书信息!\n", name);
return;
}
pre = p;
p = p->next;
}
printf("未找到书名为%s的图书!\n", name);
}
int main() {
// 创建头节点
Node* head = (Node*)malloc(sizeof(Node));
head->next = NULL;
int choice;
while (1) {
printf("\n请选择操作:\n");
printf("1. 添加图书\n");
printf("2. 输出所有图书信息\n");
printf("3. 根据书名查找图书信息\n");
printf("4. 删除指定图书信息\n");
printf("5. 退出程序\n");
scanf("%d", &choice);
switch (choice) {
case 1:
addBook(head);
break;
case 2:
printAllBooks(head);
break;
case 3:
searchBookByName(head);
break;
case 4:
deleteBook(head);
break;
case 5:
printf("程序已退出!\n");
return 0;
default:
printf("输入有误,请重新输入!\n");
break;
}
}
}
```
这个图书管理系统使用单链表来保存图书信息,包括书名、作者和库存数量。它提供了四个基本操作:添加图书、输出所有图书信息、根据书名查找图书信息和删除指定图书信息。你可以根据自己的需求进行修改和扩展。
阅读全文