运用C++语言描述书籍类、图书类型类、图书类。设计基类和派生类。要求设计具有继承与派生以及多态性的类。帮我编写一个图书管理系统,具有这些功能: 1.建立书籍类、图书类型类、图书类 2.书籍、图书类型、图书信息的初始化 3.书籍、图书类型、图书信息的添加、修改、删除、查找 4.图书信息的输出 5.对图书信息按编号、书名排序 6.将图书信息保存为文件 7.读入文件信息

时间: 2023-08-11 14:08:38 浏览: 109
ZIP

基于C++的控制台图书管理系统,可提供管理员登录和用户登录两种模式,管理员模式登录后可对图书的相关信息进行管理

好的,我将为您编写一个基于C++的图书管理系统,满足您的需求。 我们先定义三个类:书籍类 Book,图书类型类 BookType,图书类 Library。 ```cpp class Book { private: int id; // 书籍编号 string name; // 书籍名称 string author; // 作者 string publisher; // 出版社 BookType* bookType; // 书籍类型 public: Book(int id = 0, string name = "", string author = "", string publisher = "", BookType* bookType = nullptr); int getId() const; string getName() const; string getAuthor() const; string getPublisher() const; BookType* getBookType() const; void setBookType(BookType* bookType); }; class BookType { private: int id; // 图书类型编号 string name; // 图书类型名称 public: BookType(int id = 0, string name = ""); int getId() const; string getName() const; }; class Library { private: vector<Book> books; // 图书信息 vector<BookType> types; // 图书类型信息 public: void init(); // 初始化图书和图书类型 void addBook(); // 添加图书 void editBook(); // 修改图书 void deleteBook(); // 删除图书 void searchBook(); // 查找图书 void listBooks(); // 输出图书列表 void sortByNumber(); // 按编号排序 void sortByName(); // 按书名排序 void saveToFile(); // 将图书信息保存到文件 void readFromFile(); // 从文件中读取图书信息 }; ``` `Book` 类表示一本书,包含书籍编号、书籍名称、作者、出版社和图书类型。`BookType` 类表示图书类型,包含图书类型编号和图书类型名称。`Library` 类表示图书管理系统,包含一个 `vector` 类型的图书信息和图书类型信息。 下面是具体实现: ```cpp // Book 类的具体实现 Book::Book(int id, string name, string author, string publisher, BookType* bookType) { this->id = id; this->name = name; this->author = author; this->publisher = publisher; this->bookType = bookType; } int Book::getId() const { return id; } string Book::getName() const { return name; } string Book::getAuthor() const { return author; } string Book::getPublisher() const { return publisher; } BookType* Book::getBookType() const { return bookType; } void Book::setBookType(BookType* bookType) { this->bookType = bookType; } // BookType 类的具体实现 BookType::BookType(int id, string name) { this->id = id; this->name = name; } int BookType::getId() const { return id; } string BookType::getName() const { return name; } // Library 类的具体实现 void Library::init() { types.emplace_back(1, "小说"); types.emplace_back(2, "散文"); types.emplace_back(3, "诗歌"); BookType* type1 = &types[0]; BookType* type2 = &types[1]; BookType* type3 = &types[2]; books.emplace_back(1, "红楼梦", "曹雪芹", "人民文学出版社", type1); books.emplace_back(2, "西游记", "吴承恩", "人民文学出版社", type1); books.emplace_back(3, "水浒传", "施耐庵", "人民文学出版社", type1); books.emplace_back(4, "儒林外史", "吴敬梓", "人民文学出版社", type2); books.emplace_back(5, "纪录片", "方舟子", "中国青年出版社", type2); books.emplace_back(6, "静夜思", "李白", "人民文学出版社", type3); } void Library::addBook() { int id; string name, author, publisher; int typeId; cout << "请输入书籍编号:"; cin >> id; cout << "请输入书籍名称:"; cin >> name; cout << "请输入作者:"; cin >> author; cout << "请输入出版社:"; cin >> publisher; cout << "请输入书籍类型编号:"; cin >> typeId; for (auto& type : types) { if (type.getId() == typeId) { BookType* bookType = &type; books.emplace_back(id, name, author, publisher, bookType); cout << "成功添加图书!" << endl; return; } } cout << "未找到该图书类型,请先添加图书类型!" << endl; } void Library::editBook() { int id; cout << "请输入要修改的书籍编号:"; cin >> id; for (auto& book : books) { if (book.getId() == id) { string name, author, publisher; int typeId; cout << "请输入书籍名称:"; cin >> name; cout << "请输入作者:"; cin >> author; cout << "请输入出版社:"; cin >> publisher; cout << "请输入书籍类型编号:"; cin >> typeId; for (auto& type : types) { if (type.getId() == typeId) { BookType* bookType = &type; book.setBookType(bookType); book = Book(id, name, author, publisher, bookType); cout << "成功修改图书!" << endl; return; } } cout << "未找到该图书类型,请先添加图书类型!" << endl; return; } } cout << "未找到该书籍!" << endl; } void Library::deleteBook() { int id; cout << "请输入要删除的书籍编号:"; cin >> id; for (auto it = books.begin(); it != books.end(); ++it) { if (it->getId() == id) { books.erase(it); cout << "成功删除图书!" << endl; return; } } cout << "未找到该书籍!" << endl; } void Library::searchBook() { int choice; cout << "1.按书籍编号查找\n2.按书籍名称查找\n请选择:"; cin >> choice; if (choice == 1) { int id; cout << "请输入书籍编号:"; cin >> id; for (auto& book : books) { if (book.getId() == id) { cout << "书籍编号:" << book.getId() << endl; cout << "书籍名称:" << book.getName() << endl; cout << "作者:" << book.getAuthor() << endl; cout << "出版社:" << book.getPublisher() << endl; cout << "书籍类型编号:" << book.getBookType()->getId() << endl; cout << "书籍类型名称:" << book.getBookType()->getName() << endl; return; } } cout << "未找到该书籍!" << endl; } else if (choice == 2) { string name; cout << "请输入书籍名称:"; cin >> name; for (auto& book : books) { if (book.getName() == name) { cout << "书籍编号:" << book.getId() << endl; cout << "书籍名称:" << book.getName() << endl; cout << "作者:" << book.getAuthor() << endl; cout << "出版社:" << book.getPublisher() << endl; cout << "书籍类型编号:" << book.getBookType()->getId() << endl; cout << "书籍类型名称:" << book.getBookType()->getName() << endl; return; } } cout << "未找到该书籍!" << endl; } } void Library::listBooks() { cout << "书籍编号\t书籍名称\t作者\t出版社\t书籍类型编号\t书籍类型名称" << endl; for (auto& book : books) { cout << book.getId() << "\t\t" << book.getName() << "\t\t" << book.getAuthor() << "\t\t" << book.getPublisher() << "\t\t" << book.getBookType()->getId() << "\t\t" << book.getBookType()->getName() << endl; } } void Library::sortByNumber() { sort(books.begin(), books.end(), [](const Book& a, const Book& b) { return a.getId() < b.getId(); }); } void Library::sortByName() { sort(books.begin(), books.end(), [](const Book& a, const Book& b) { return a.getName() < b.getName(); }); } void Library::saveToFile() { ofstream outFile("books.txt"); if (outFile.is_open()) { for (auto& book : books) { outFile << book.getId() << "," << book.getName() << "," << book.getAuthor() << "," << book.getPublisher() << "," << book.getBookType()->getId() << endl; } cout << "成功保存图书信息到文件 books.txt!" << endl; } else { cout << "无法打开文件 books.txt!" << endl; } outFile.close(); } void Library::readFromFile() { ifstream inFile("books.txt"); if (inFile.is_open()) { books.clear(); string line; while (getline(inFile, line)) { stringstream ss(line); string str; int id, typeId; string name, author, publisher; getline(ss, str, ','); id = stoi(str); getline(ss, name, ','); getline(ss, author, ','); getline(ss, publisher, ','); getline(ss, str); typeId = stoi(str); for (auto& type : types) { if (type.getId() == typeId) { BookType* bookType = &type; books.emplace_back(id, name, author, publisher, bookType); break; } } } cout << "成功从文件 books.txt 读取图书信息!" << endl; } else { cout << "无法打开文件 books.txt!" << endl; } inFile.close(); } ``` 在 `init()` 函数中,我们初始化了一些书籍和图书类型。在 `addBook()` 函数中,我们首先输入书籍信息,然后判断输入的图书类型是否存在,如果存在,就添加该图书到 `books` 中。在 `editBook()` 函数中,我们首先输入要修改的书籍编号,然后遍历 `books` 列表找到该书籍,再输入新的书籍信息,最后修改该书籍的信息。在 `deleteBook()` 函数中,我们首先输入要删除的书籍编号,然后遍历 `books` 列表找到该书籍,最后删除该书籍。在 `searchBook()` 函数中,我们可以选择按书籍编号或者按书籍名称来查找书籍,找到该书籍之后输出书籍信息。在 `listBooks()` 函数中,我们遍历 `books` 列表输出所有书籍信息。在 `sortByNumber()` 和 `sortByName()` 函数中,我们分别按书籍编号和书籍名称进行排序。在 `saveToFile()` 函数中,我们将 `books` 列表中的所有书籍信息保存到文件 `books.txt` 中。在 `readFromFile()` 函数中,我们从文件 `books.txt` 中读取图书信息。 现在我们可以在 `main()` 函数中调用上面的函数来实现图书管理系统了。 ```cpp int main() { Library library; library.init(); while (true) { cout << "1.添加图书\n2.修改图书\n3.删除图书\n4.查找图书\n5.输出图书列表\n6.按编号排序\n7.按书名排序\n8.将图书信息保存到文件\n9.从文件中读取图书信息\n0.退出\n请选择:"; int choice; cin >> choice; switch (choice) { case 1: library.addBook(); break; case 2: library.editBook(); break; case 3: library.deleteBook(); break; case 4: library.searchBook(); break; case 5: library.listBooks(); break; case 6: library.sortByNumber(); break; case 7: library.sortByName(); break; case 8: library.saveToFile(); break; case 9: library.readFromFile(); break; case 0: return 0; default: cout << "无效的选项!" << endl; } } return 0; } ``` 以上就是一个简单的图书管理系统的实现。
阅读全文

相关推荐

最新推荐

recommend-type

很好的MFC学习资料 适合刚学习MFC的朋友

MFC利用C++的虚函数和动态绑定机制,使得在运行时可以确定消息的正确接收者,从而实现多态性和动态消息路由。通过消息映射(Message Map),MFC将消息与处理函数关联,使得不同对象可以响应相同的消息。 5. **MFC...
recommend-type

FTP上传下载工具,支持上传下载文件夹、支持进度更新.7z

FTP上传下载工具,支持上传下载文件夹、支持进度更新.7z
recommend-type

[机械毕业设计方案]立式二级圆锥圆柱齿轮减速器.zip

文件放服务器下载,请务必到电脑端资源预览或者资源详情查看然后下载
recommend-type

非常好的32个毕业设计系统电路proteus仿真工程100%好用.zip

非常好的32个毕业设计系统电路proteus仿真工程100%好用.zip
recommend-type

室内模型,.dxf格式

室内模型,.dxf格式
recommend-type

创建个性化的Discord聊天机器人教程

资源摘要信息:"discord_bot:用discord.py制作的Discord聊天机器人" Discord是一个基于文本、语音和视频的交流平台,广泛用于社区、团队和游戏玩家之间的通信。Discord的API允许开发者创建第三方应用程序,如聊天机器人(bot),来增强平台的功能和用户体验。在本资源中,我们将探讨如何使用Python库discord.py来创建一个Discord聊天机器人。 1. 使用discord.py创建机器人: discord.py是一个流行的Python库,用于编写Discord机器人。这个库提供了一系列的接口,允许开发者创建可以响应消息、管理服务器、与用户交互等功能的机器人。使用pip命令安装discord.py库,开发者可以开始创建和自定义他们的机器人。 2. discord.py新旧版本问题: 开发者在创建机器人时应确保他们使用的是与Discord API兼容的discord.py版本。本资源提到的机器人是基于discord.py的新版本,如果开发者有使用旧版本的需求,资源描述中指出需要查看相应的文档或指南。 3. 命令清单: 机器人通常会响应一系列命令,以提供特定的服务或功能。资源中提到了一些默认前缀“努宗”的命令,例如:help命令用于显示所有公开命令的列表;:epvpis 或 :epvp命令用于进行某种搜索。 4. 自定义和自托管机器人: 本资源提到的机器人是自托管的,并且设计为高度可定制。这意味着开发者可以完全控制机器人的运行环境、扩展其功能,并将其部署在他们选择的服务器上。 5. 关键词标签: 文档的标签包括"docker", "cog", "discord-bot", "discord-py", 和 "python-bot"。这些标签指示了与本资源相关的技术领域和工具。例如,Docker可用于容器化应用程序,使得机器人可以在任何支持Docker的操作系统上运行,从而提高开发、测试和部署的一致性。标签"python-bot"强调了使用Python语言创建Discord机器人的重要性,而"cog"可能是指在某些机器人框架中用作模块化的代码单元。 6. 文件名称列表: 资源中的"discord_bot-master"表明这是从一个源代码仓库获取的,可能是GitHub上公开的项目。"master"通常是指项目的主分支或主要版本。 总结: 通过本资源,开发者可以学习到如何利用Python和discord.py库来创建功能丰富的Discord聊天机器人。资源涵盖了安装库、创建命令响应、自托管机器人、以及如何根据新旧版本API进行适配等内容。这不仅对初学者入门,对有经验的开发者进一步学习和提升技能也是有价值的。通过理解这些知识点,开发者可以构建出适合他们需要的自定义机器人,进而为Discord社区提供附加价值。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【Eclipse软件终极指南】:油藏数值模拟新手到专家的必经之路

![【Eclipse软件终极指南】:油藏数值模拟新手到专家的必经之路](https://ucc.alicdn.com/pic/developer-ecology/ajpxbl4ljzs5k_9cbe41a1e6e34e6a87c7f49567bdef32.jpeg?x-oss-process=image/resize,s_500,m_lfit) 参考资源链接:[油藏数值模拟基础:ECLIPSE软件详解](https://wenku.csdn.net/doc/2v49ka4j2q?spm=1055.2635.3001.10343) # 1. Eclipse软件概述及应用领域 ## 1.1 软
recommend-type

mvn 命令打包时 指定jdk 的版本、和环境变量

当使用`mvn`命令打包时,有时确实需要指定特定版本的Java Development Kit (JDK) 或设置环境变量,特别是当你的项目依赖于某个特定版本或者你需要在不同的JDK环境下进行构建。以下是两个关键的部分: 1. **指定JDK版本**: 如果你想强制`mvn`使用特定的JDK版本,可以在`.mvn/wrapper/maven-wrapper.properties`文件中添加`maven.jdk.home`属性,然后更新其值指向你想要使用的JDK安装路径。例如: ``` maven.jdk.home=/path/to/jdk-version ```
recommend-type

RequireJS实现单页应用延迟加载模块示例教程

资源摘要信息:"example-onepage-lazy-load是一个基于RequireJS的单页或多页应用程序示例项目,该项目展示了如何实现模块的延迟加载。延迟加载是一种编程技术,旨在在需要时才加载应用程序的某些部分,从而提高应用程序的初始加载速度和性能。RequireJS是一个JavaScript文件和模块加载器,它能够管理JavaScript文件的依赖关系,并且通过异步加载模块,可以进一步优化页面加载性能。 在这个示例项目中,开发者可以了解到如何使用RequireJS来实现模块的懒加载。这涉及到了几个关键点: 1. 将应用程序分为多个模块,这些模块在不立即需要时不会被加载。 2. 使用RequireJS的配置来定义模块之间的依赖关系,以及如何异步加载这些依赖。 3. 通过合并JavaScript文件,减少页面请求的数量,这有助于降低服务器负载并减少延迟。 4. 利用RequireJS的优化器(r.js)来拆分构建目标,生成更小的文件,这有助于加速应用的启动时间。 RequireJS的工作原理基于模块化编程的概念,它允许开发者将JavaScript代码拆分成逻辑块,每一个块都包含特定的功能。这些模块可以被定义为依赖其他模块,RequireJS则负责按照正确的顺序加载这些模块。它提供了一个全局的`require()`函数,开发者可以通过这个函数来声明他们的代码依赖和加载其他模块。 这个示例项目也强调了模块化和代码组织的重要性。项目的布局设计得非常简单明了,通常包含以下几个部分: - `build`目录:存放RequireJS优化器的配置文件(如option.js),用于指定如何打包和优化模块。 - `www`目录:包含所有静态资源,比如HTML页面、样式表和图片等。这个目录的结构旨在让静态资源独立于应用逻辑,便于部署和维护。 在项目中使用RequireJS可以带来几个显著的好处: - 模块化能够改善代码的组织和维护性。 - 异步加载可以减少页面加载时间,提升用户体验。 - 通过合并和压缩文件,可以减少HTTP请求的数量,加快页面渲染速度。 关于`r.js`,它是RequireJS项目中的一个命令行工具,用于自动化模块的打包和优化过程。它能够读取RequireJS的配置文件,自动处理依赖关系,合并模块,并输出优化后的文件。这对于生产环境中的代码部署尤其有用,因为它能够将多个JavaScript文件压缩成一个或几个较小的文件,从而减少网络传输的负担。 总结来说,这个示例项目演示了如何使用RequireJS来实现延迟加载和模块化,这对于优化现代Web应用的性能和管理大型代码库至关重要。开发者可以借鉴这个项目来提高自己的JavaScript应用性能,以及更好地理解和应用RequireJS的特性和最佳实践。"