C++图书管理系统(简单版)

2023-10-26

1、系统需求

图书管理系统是一个可以记录图书借记和存储的工具。

本教程主要利用C++来实现一个图书管理系统

系统中需要实现的功能如下:

添加书籍:向图书管理系统中添加新书,信息包括(书名、书的价格、书的编号)最多记录1000本

显示书籍:显示图书的所有书籍信息

书籍删除:按照书名进行删除指定书籍

查找书籍:按照姓名查看指定书籍信息

修改书籍:按照姓名重新修改指定书籍

清空书架:清空书架中所有信息

退出图书管理系统:退出当前使用的系统

2、菜单功能

功能描述:用户选择功能的界面

步骤:

封装函数显示该界面,如:void menu()

在main函数中调用封装好的函数

void mean(){
    cout << "*************************" << endl;
    cout << "*******1、加入图书********" << endl; //OK
    cout << "*******2、按名删除图书*****" << endl;//OK
    cout << "*******3、按名查找图书*****" << endl;//OK
    cout << "*******4、清空图书架*******" << endl;//OK
    cout << "*******5、修改图书名*******" << endl;
    cout << "*******6、显示图书架*******" << endl;//OK
    cout << "*******0、退出系统*********" << endl; //OK
    cout << "**************************" << endl;

}

3、退出功能

功能描述:退出通讯录系统

思路:根据用户不同的选择,进入不同的功能,可以选择switch分支结构,将整个架构进行搭建

当用户选择0的时候,执行退出,选择其他先不做操作,也不会退出程序

int outSystem(){
    cout << "欢迎下次使用" << endl;
    return 0;
}

4、添加联系人

功能描述:

实现添加书籍功能,书籍上限为1000人,联系人信息包括(书籍名称、书籍价格、书籍编号)

添加书籍实现步骤:

设计图书系统结构体

设计图书系统结构体

main函数中创建系统

封装添加书籍函数

测试添加图书功能

4.1 设计书籍结构体

书籍信息包括:书籍姓名、书籍价格、书籍编号

void addBooks(Arraybooks *abs){
    if(abs->length >= MAX){
        cout << "书籍已满" << endl;
    }else {
        string name;
        cout << "请输入书籍的名字: " << endl;
        cin >> name;
        abs->book[abs->length].name = name;


        int price;
        cout << "请输入书的价格: " << endl;
        cin >> price;
        abs->book[abs->length].price = price;


        string num;
        cout << "请输入书的编号: " << endl;
        cin >> num;
        abs->book[abs->length].number = num;


        abs->length++;


        cout << "添加成功" << endl;
        }
    }

5、显示书籍

功能描述:显示图书系统中已有的书籍信息

显示图书实现步骤:

封装显示图书函数

测试显示图书功能

void showbooks(Arraybooks*abs){
    if(abs->length == 0){
        cout << "书架为空"<< endl;
    }else{
        for (int i = 0; i < abs->length; ++i) {
            cout << "书籍名字 : " <<abs->book[i].name << "\t";
            cout << "书籍价格 : " <<abs->book[i].price << "\t";
            cout << "书籍编号 : " << abs->book[i].number <<endl;
        }
    }
}

6、删除图书

实现步骤:

1、封装检测图书是否存在

2、封装删除图书函数

3、测试删除图书功能

6.1 封装检测图书是否存在

设计思路:

删除图书前,我们需要先判断图书是否存在,如果存在删除,不存在提示图书系统没有要删除的书籍,因此我们可以把检测联系人是否存在封装成一个函数中,如果存在,返回联系人在图书系统中的位置,不存在返回-1。

int isExist(Arraybooks *abs , string name){
    for (int i = 0; i < abs->length; ++i) {
        if(abs->book[i].name == name){
            return i;
        }
    }
    return -1;
}

6.2 封装删除图书函数

根据用户输入的图书名判断该系统中是否有此书

查找到进行删除,并提示删除成功

查不到提示查无此书

void dalateBooks(Arraybooks* abs) {
    cout << "请输入你要删除的书籍" << endl;
    string name;
    cin >> name;

    int ret = isExist(abs, name);
    if (ret != -1 && ret != abs->length - 1) {
          abs->book[ret].name     = abs->book[ret + 1].name;
          abs->book[ret].number   = abs->book[ret + 1].number;
          abs->book[ret].price    = abs->book[ret + 1].price;
        for (int i = ret + 2; i < abs->length; ++i) {
          abs->book[i - 1].name   = abs->book[i].name;
          abs->book[i - 1].number = abs->book[i].number;
          abs->book[i - 1].price  = abs->book[i].price;
          abs->length--;
        }
        cout << "删除成功" << endl;
    }
    else if(ret != 1 && ret == abs->length - 1) {
        abs->length--;
    }
    else {
        cout << "查无此书" << endl;
    }
}

7、查找书籍

功能描述:按照姓名查看指定书籍信息

查找书籍实现步骤

1、封装查找书籍函数

2、测试查找指定书籍

7.1 封装查找书籍函数

实现思路:判断用户指定的书籍是否存在,如果存在显示信息,不存在则提示查无此书。

void CheckBook(Arraybooks * abs){
    cout << "输入你要查找的书籍"  << endl;
    string name;
    cin >> name;

    int ret = isExist(abs , name);
    if(ret != -1){
        cout << "书名为:" << abs->book[ret].name << "\t";
        cout << "书价格为:" << abs->book[ret].price << "\t";
        cout << "书编号为:" << abs->book[ret].number << endl;
    }
    else{
        cout << "查无此书" << endl;
    }
}

8、修改书籍

功能描述:按照姓名重新修改指定书籍

修改书籍实现步骤

1、封装修改书籍函数

2、测试修改书籍功能

8.1 封装修改书籍函数

实现思路:查找用户输入的书籍,如果查找成功进行修改操作,查找失败提示查无此书。

void changebooks(Arraybooks * abs){
    cout << "输入你要修改的图书" << endl;
    string name;
    cin >> name;
    int ret = isExist(abs , name);
    if(ret != -1){
        cout << "请输入名字: " << endl;
        string name;
        cin >> name;
        abs->book[ret].name = name;

        cout << "请输入价格: " << endl;
        int price;
        cin >> price;
        abs->book[ret].price = price;

        cout << "请输入编号: " << endl;
        string num;
        cin >> num;
        abs->book[ret].number = num;
    }else{
        cout << "查无此书" << endl;
    }

}

9、清空书籍

功能描述:清空书籍中所有信息

清空书籍实现步骤

1、封装清空书籍函数

2、测试清空书籍

9.1封装清空书籍函数

实现思路:将书籍所有书籍信息清楚掉,只要将图书管理系统记录的书籍数量置为0,做逻辑清空即可。

void cleanbooks(Arraybooks * abs){
    abs->length = 0;
    cout << "清理完成" << endl;

}

完整代码

#include <iostream>
#include <string>


using namespace std;
#define MAX 1000
struct Person {
    string name;
    int price;
    string number;
};

struct Arraybooks {
    struct Person book[MAX];
    int length;
};

void mean();
int  outSystem();
void addBooks(Arraybooks* abs);
void dalateBooks(Arraybooks* abs);
int  isExist(Arraybooks* abs, string name);
void CheckBook(Arraybooks* abs);
void cleanbooks(Arraybooks* abs);
void showbooks(Arraybooks* abs);
void changebooks(Arraybooks* abs);

int main() {
    int x;
    Arraybooks abs;
    abs.length = 0;

    while (true) {
        mean();
        cin >> x;
        switch (x) {
        case 1:
            addBooks(&abs);
            break;
        case 2:
            dalateBooks(&abs);
            break;
        case 3:
            CheckBook(&abs);
            break;
        case 4:
            cleanbooks(&abs);
            break;
        case 5:
            changebooks(&abs);
            break;
        case 6:
            showbooks(&abs);
            break;
        case 0:
            outSystem();
            break;


        }


    }
    return 0;
}
void addBooks(Arraybooks* abs) {
    if (abs->length >= MAX) {
        cout << "书籍已满" << endl;
    }
    else {
        string name;
        cout << "请输入书籍的名字: " << endl;
        cin >> name;
        abs->book[abs->length].name = name;


        int price;
        cout << "请输入书的价格: "  << endl;
        cin >> price;
        abs->book[abs->length].price = price;


        string num;
        cout << "请输入书的编号: "  << endl;
        cin >> num;
        abs->book[abs->length].number = num;


        abs->length++;


        cout << "添加成功" << endl;
    }
}


int isExist(Arraybooks* abs, string name) {
    for (int i = 0; i < abs->length; ++i) {
        if (abs->book[i].name == name) {
            return i;
        }
    }
    return -1;
}

void dalateBooks(Arraybooks* abs) {
    cout << "请输入你要删除的书籍" << endl;
    string name;
    cin >> name;

    int ret = isExist(abs, name);
    if (ret != -1 && ret != abs->length - 1) {
          abs->book[ret].name     = abs->book[ret + 1].name;
          abs->book[ret].number   = abs->book[ret + 1].number;
          abs->book[ret].price    = abs->book[ret + 1].price;
        for (int i = ret + 2; i < abs->length; ++i) {
          abs->book[i - 1].name   = abs->book[i].name;
          abs->book[i - 1].number = abs->book[i].number;
          abs->book[i - 1].price  = abs->book[i].price;
          abs->length--;
        }
        cout << "删除成功" << endl;
    }
    else if(ret != 1 && ret == abs->length - 1) {
        abs->length--;
    }
    else {
        cout << "查无此书" << endl;
    }
}

void CheckBook(Arraybooks* abs) {
    cout << "输入你要查找的书籍" << endl;
    string name;
    cin >> name;

    int ret = isExist(abs, name);
    if (ret != -1) {
        cout << "书名为:"   << abs->book[ret].name   << "\t";
        cout << "书价格为:" << abs->book[ret].price  << "\t";
        cout << "书编号为:" << abs->book[ret].number << endl;
    }
    else {
        cout <<  "查无此书"  << endl;
    }
}

void cleanbooks(Arraybooks* abs) {
    abs->length = 0;
    cout << "清理完成" << endl;

}

void changebooks(Arraybooks* abs) {
    cout << "输入你要修改的图书" << endl;
    string name;
    cin >> name;
    int ret = isExist(abs, name);
    if (ret != -1) {
        cout << "请输入名字: " << endl;
        string name;
        cin >> name;
        abs->book[ret].name   = name;

        cout << "请输入价格: " << endl;
        int price;
        cin >> price;
        abs->book[ret].price  = price;

        cout << "请输入编号: "  << endl;
        string num;
        cin >> num;
        abs->book[ret].number = num;
    }
    else {
        cout << "查无此书"      << endl;
    }

}

void showbooks(Arraybooks* abs) {
    if (abs->length == 0) {
        cout << "书架为空" << endl;
    }
    else {
        for (int i = 0; i < abs->length; ++i) {
            cout << "书籍名字 : " << abs->book[i].name   << "\t";
            cout << "书籍价格 : " << abs->book[i].price  << "\t";
            cout << "书籍编号 : " << abs->book[i].number << endl;
        }
    }
}

int outSystem() {
    cout << "欢迎下次使用" << endl;
    return 0;
}


void mean() {
    cout << "*************************" << endl;
    cout << "*******1、加入图书********" << endl; //OK
    cout << "*******2、按名删除图书****" << endl;//OK
    cout << "*******3、按名查找图书****" << endl;//OK
    cout << "*******4、清空图书架******" << endl;//OK
    cout << "*******5、修改图书名******" << endl;
    cout << "*******6、显示图书架******" << endl;//OK
    cout << "*******0、退出系统********" << endl; //OK
    cout << "*************************" << endl;

}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C++图书管理系统(简单版) 的相关文章

随机推荐

  • tan和atan--正切和反正切函数

    功能简介 求变量的正切和反正切 语法格式 1 Y tan X 求X中元素的正切值 元素可以为复数 tan函数是周期函数 以pi为一个周期 当元素值等于pi 2的奇数倍时 函数失去定义 在三角函数中 tan x sin x cos x 2 Y
  • P1025 数的划分(dfs/dp)

    题目 https www luogu com cn problem P1025 题目描述 将整数n分成k份 且每份不能为空 任意两个方案不相同 不考虑顺序 例如 n 7 k 3 下面三种分法被认为是相同的 1 1 5 1 5 1 5 1 1
  • 关于vscode头文件出现红色波浪曲线问题

    关于vscode头文件总显示红色波浪曲线解决 方法1 可以在设置中直接关掉 方法2 没有添加编译器的路径 我们可以找到gcc exe所在的路径 或者重新安装官网下载 解压到c盘非中文路径 复制路径 主要是看gcc g 所在的路径
  • 环信iOS使用步骤及使用总结

    环信iOS使用步骤及使用总结 第一步 集成 请参照环信官方文档http docs easemob com im 300iosclientintegration 20iossdkimport 集成 iOSSDK 在您阅读此文档时 我们假定您已
  • OpenAI最新官方ChatGPT聊天插件接口《插件部署上生产》全网最详细中英文实用指南和教程,助你零基础快速轻松掌握全新技术(五)(附源码)

    Plugins in production 插件部署上生产 前言 Rate limits 速率限制 Updating your plugin 更新您的插件 Plugin terms Domain verification and secur
  • TCP与UDP的区别

    一 前言 TCP IP 中有两个具有代表性的传输层协议 分别是 TCP 和 UDP 二 TCP IP网络模型 计算机与网络设备要相互通信 双方就必须基于相同的方法 比如 如何探测到通信目标 由哪一边先发起通信 使用哪种语言进行通信 怎样结束
  • 因果推断4--Causal ML(个人笔记)

    目录 1 安装教程及官方文档 1 1 pip安装 1 2 API文档 1 3 代码仓库 2 Uplift模型与主要方法介绍 2 1 发放代金券 2 2 多treatment 2 3 实验方法 3 causalml inference tre
  • IDEA中使用单元测试(Junit)Scanner控制台无法输入问题解决 2022.12.13

    步骤 Help Edit Custom VM options 在idea64 exe vmoptions文件中最后一行添加如下内容 Deditable java test console true 操作完成保存后一定要重启IDEA ps 通
  • Vue中读取本地图片实现预览和上传

    先看效果图 上面展示了两张从本地添加的准备上传服务器的预览图片 效果还不错吧 哈哈哈 下面是该页面中紫色框的布局与实现代码 我想有些人也不喜欢HTML中默认的上传文件样式 实在辣眼睛
  • C\C++ 中的绝对值函数:abs()、cabs()、fabs()、labs()

    不同类型的数据使用不同类型的绝对值函数 整型 int abs int i 返回整型参数i的绝对值 复数 double cabs struct complex znum 返回复数znum的绝对值 双精度浮点型 double fabs doub
  • egg-swagger token验证无效解决方案

    先看效果 注意 我这边只讲重点 1 首先 egg swagger 怎么安装看我的这篇egg swagger demo 无数据库版 2 无swagger的 token 验证 我的这篇eggjs token生成和验证demo 3 我这边只讲 重
  • Raft一致性算法

    摘要 Raft 是一种为了管理复制日志的一致性算法 它提供了和 Paxos 算法相同的功能和性能 但是它的算法结构和 Paxos 不同 使得 Raft 算法更加容易理解并且更容易构建实际的系统 为了提升可理解性 Raft 将一致性算法分解成
  • Prometheus详解(四)——Prometheus简单使用

    今天继续给大家介绍Linux运维相关知识 本文主要内容是Prometheus简单使用 在上文Prometheus详解 三 Prometheus安装部署中 我们介绍了Prometheus的安装和部署 今天 我们就来介绍一下Prometheus
  • fork()父子进程变量之间的关系与信号的响应

    1 变量关系 根据 unix 高级环境编程 中的一句话 子进程和父进程继续执行fork调用之后的指令 子进程是父进程的副本 例如 子进程获取父进程数据空间 堆和栈的副本 注意 这是子进程所拥有的副本 父子进程并不共享这些存储空间部分 父子进
  • 尚品汇细节分析-Vue项目中如何实现自定义校验规则

    需求 当用户登录时 会输入用户名和密码 用户名不能为空 密码的长度不能小于6位 需要在用户在点击登录按钮前 进行验证是否通过我们设定的规则 如果通过则放行 如果不通过则会进行提示 效果图 结合Element UI来实现校验规则 1 页面元素
  • SQL SERVER 2000 遍历父子关系数据的表(二叉树)获得所有子节点 所有父节点及节点层数函数

    SQL SERVER 2000 遍历父子关系數據表 二叉树 获得所有子节点 所有父节点及节点层数函数 Geovin Du 涂聚文 建立測試環境 Create Table GeovinDu ID Int fatherID Int Name V
  • 课程设计-基于Java web的网吧管理系统

    项目编号 B01 项目名称 基于Java jsp Servlet的网吧管理系统 源码编号 BK05 项目类型 Java web项目 JavaEE 当前版本 V1 0 0版本 用户类型 只有管理员 单角色 项目架构 B S架构 设计思想 MV
  • IDEA快捷键(WIN10,持续更新)

    IDEA快捷键 以下所说的都是windows下的默认快捷键 可以通过File gt Settings gt Keymap 对快捷键进行修改 查看源码 ctrl 鼠标左键 重写父类方法 ctrl o 快速写for循环 20 for或fori
  • python给图片加雾

    调用的是cv2的addWeighted函数 增雾结果来看效果还蛮不错的 import numpy as np import cv2 as cv import os import random file C Users Ilearn Desk
  • C++图书管理系统(简单版)

    1 系统需求 图书管理系统是一个可以记录图书借记和存储的工具 本教程主要利用C 来实现一个图书管理系统 系统中需要实现的功能如下 添加书籍 向图书管理系统中添加新书 信息包括 书名 书的价格 书的编号 最多记录1000本 显示书籍 显示图书