用c语言链表编译图书管理系统(不含文件)
时间: 2023-08-10 08:17:23 浏览: 106
好的,我可以帮你解答这个问题。首先,我们需要定义一个图书的结构体,包含书名、作者、价格等信息。然后,我们可以使用链表来存储这些图书信息。下面是一个基本的代码框架:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//定义图书结构体
typedef struct book {
char name[50];
char author[20];
float price;
struct book *next;
} Book;
//链表头指针
Book *head = NULL;
//添加图书
void add_book() {
Book *p = (Book*)malloc(sizeof(Book));
printf("请输入书名:");
scanf("%s", p->name);
printf("请输入作者:");
scanf("%s", p->author);
printf("请输入价格:");
scanf("%f", &p->price);
p->next = head;
head = p;
printf("添加成功!\n");
}
//删除图书
void delete_book() {
char name[50];
printf("请输入要删除的图书名称:");
scanf("%s", name);
Book *p = head;
Book *q = NULL;
while (p != NULL && strcmp(p->name, name) != 0) {
q = p;
p = p->next;
}
if (p == NULL) {
printf("未找到该图书!\n");
return;
}
if (q == NULL) {
head = p->next;
} else {
q->next = p->next;
}
free(p);
printf("删除成功!\n");
}
//查找图书
void find_book() {
char name[50];
printf("请输入要查找的图书名称:");
scanf("%s", name);
Book *p = head;
while (p != NULL && strcmp(p->name, name) != 0) {
p = p->next;
}
if (p == NULL) {
printf("未找到该图书!\n");
return;
}
printf("书名:%s,作者:%s,价格:%.2f\n", p->name, p->author, p->price);
}
//显示所有图书
void show_books() {
if (head == NULL) {
printf("暂无图书!\n");
return;
}
Book *p = head;
while (p != NULL) {
printf("书名:%s,作者:%s,价格:%.2f\n", p->name, p->author, p->price);
p = p->next;
}
}
int main() {
int choice;
while (1) {
printf("请选择操作:\n");
printf("1.添加图书\n");
printf("2.删除图书\n");
printf("3.查找图书\n");
printf("4.显示所有图书\n");
printf("5.退出系统\n");
scanf("%d", &choice);
switch (choice) {
case 1:
add_book();
break;
case 2:
delete_book();
break;
case 3:
find_book();
break;
case 4:
show_books();
break;
case 5:
return 0;
default:
printf("输入有误,请重新输入!\n");
break;
}
}
return 0;
}
```
这是一个基本的图书管理系统,包括添加图书、删除图书、查找图书和显示所有图书等功能。你可以根据自己的需求来扩展功能,例如修改图书信息、排序等。同时,由于本程序没有使用文件来保存图书信息,所以程序结束后所有数据都会丢失,如果需要长期保存数据,可以使用文件来存储。
阅读全文