C语言实现强大图书信息管理系统:增删改查排序功能全搞定
```c #include <stdio.h> #include <stdlib.h> // 定义图书结构体 typedef struct { char title[50]; char author[50]; float price; } Book; // 定义图书表 Book bookTable[100]; int bookCount = 0; // 根据指定图书个数,逐个输入图书信息 void inputBookInfo(int count) { for (int i = 0; i < count; i++) { printf("请输入第%d本图书的", i+1); scanf(" %[^\n]", bookTable[bookCount].title); printf("请输入第%d本图书的作者:", i+1); scanf(" %[^\n]", bookTable[bookCount].author); printf("请输入第%d本图书的价格:", i+1); scanf("%f", &bookTable[bookCount].price); bookCount++; } } // 逐个显示图书表中所有图书的相关信息 void displayBookInfo() { printf("图书信息:\n"); for (int i = 0; i < bookCount; i++) { printf("%d. %s 作者:%s 价格:%.2f\n", i+1, bookTable[i].title, bookTable[i].author, bookTable[i].price); } } // 将新图书插入到图书表中指定的位置 void insertBook(int position, Book newBook) { for (int i = bookCount; i > position; i--) { bookTable[i] = bookTable[i-1]; } bookTable[position] = newBook; bookCount++; } // 将该图书从图书表中删除 void deleteBook(int position) { for (int i = position; i < bookCount-1; i++) { bookTable[i] = bookTable[i+1]; } bookCount--; } // 统计表中图书总数 void countBooks() { printf("图书总数:%d\n", bookCount); } // 使用冒泡排序算法按照图书价格降序排序 void sortBooks() { for (int i = 0; i < bookCount-1; i++) { for (int j = 0; j < bookCount-i-1; j++) { if (bookTable[j].price < bookTable[j+1].price) { Book temp = bookTable[j]; bookTable[j] = bookTable[j+1]; bookTable[j+1] = temp; } } } } int main() { int choice; do { printf("\n图书信息管理系统菜单:\n"); printf("1. 输入图书信息\n"); printf("2. 显示图书信息\n"); printf("3. 插入图书\n"); printf("4. 删除图书\n"); printf("5. 统计图书总数\n"); printf("6. 按价格排序\n"); printf("7. 退出\n"); printf("请选择操作:"); scanf("%d", &choice); switch(choice) { case 1: { int count; printf("请输入图书个数:"); scanf("%d", &count); inputBookInfo(count); break; } case 2: displayBookInfo(); break; case 3: { Book newBook; int position; printf("请输入要插入的位置:"); scanf("%d", &position); printf("请输入要插入的图书的"); scanf(" %[^\n]", newBook.title); printf("请输入要插入的图书的作者:"); scanf(" %[^\n]", newBook.author); printf("请输入要插入的图书的价格:"); scanf("%f", &newBook.price); insertBook(position-1, newBook); break; } case 4: { int position; printf("请输入要删除的位置:"); scanf("%d", &position); deleteBook(position-1); break; } case 5: countBooks(); break; case 6: sortBooks(); break; case 7: exit(0); break; default: printf("无效选择!\n"); } } while (1); return 0; } ``` ######[AI写代码神器 | 2512点数解答 | 2024-06-30 22:44:24]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)371
- Python 实战:学生信息列表转字典、遍历、深拷贝及数据修改全流程(GPT | 422点数解答 | 2024-10-29 15:43:54)441
- Python实战:学生成绩列表转字典,深拷贝与数据修改操作全解析(字节豆包 | 254点数解答 | 2024-10-29 16:01:39)435
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)342
- 深度剖析:黑盒、白盒、单元、集成、系统与验收测试的区别与联系 (百度文心 | 424点数解答 | 2023-11-09 18:24:11)314
- Spring Boot 打造 MallShop 购物商城:多角色权限、全业务功能的 Web 应用奇迹 (GPT | 1095点数解答 | 2024-12-09 14:06:47)383
- C++实现银行排队系统:从思路到代码的完整解析(讯飞星火 | 2048点数解答 | 2024-12-11 15:11:23)502
- Windows 10 下用按键精灵:鼠标左键一键绑定窗口及代码详解与注意要点(字节豆包 | 509点数解答 | 2025-08-24 23:34:49)257
- Windows 10 下按键精灵:鼠标左键一次点击绑定窗口代码详解及开发注意事项 (字节豆包 | 372点数解答 | 2025-08-24 23:43:42)170
- Windows 系统下按键精灵:绑定窗口实现鼠标左键点击及开发注意要点(DeepSeek | 126点数解答 | 2025-08-24 23:48:27)152
- iOS开发:手把手教你完整实现代理模式,含声明与实现步骤!(阿里通义 | 268点数解答 | 2023-11-08 00:39:55)271
- JavaScript 开发:用 Animation 实现自定义动画的简易教程 (阿里通义 | 333点数解答 | 2023-11-09 01:50:07)263