C++实现图书信息管理系统

 更新时间:2022年03月12日 11:17:02   作者:ōu yǐng  
这篇文章主要为大家详细介绍了C++实现图书信息管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C++实现图书信息管理系统的具体代码,供大家参考,具体内容如下

1.题目:

类型有:编号:ISBN
书名:name
价格:price

完成如下的功能:

①录入:从键盘输入(或从文件读入)图书(或学生)信息表的各个数据元素;
②查找:可按不同属性查找所有等于给定值的数据元素,找到并返回它们在表中的位序;
③插入:在表中第i(1=<i<=N+1)个位置插入一个新元素;
④删除:可删除表中第i(1=<i<=N)个位置上的元素;
⑤输出:依次打印表中的各个元素的值;
⑥排序:可按某属性对表中的元素进行排序。(可选)

2.实现方式:单链表(带头节点)

3.代码实现:

#include <iostream>
#include <string>
using namespace std;

struct Node
{
    int ISBN;//编号
    string name;//书名
    float price;//定价
    Node *next;
};

//操作类
class Link
{
private:
    int number;//图书数量
    Node *head;
public:
    Link(int a):number(a){}
    ~Link(){delete head;}
    void create_node();//创建
    void select();//功能选择
    int find_node(int i);//按照编号查找
    int find_node(string n);//按照书名查找
    int find_node(float p);//按照价格查找
    int insert_node(int pos);//插入
    int delete_node(int d);//删除
    int mod_node(int d);//修改
    void sort_node_ISBN();//按照编号排序
    void sort_node_price();//按照价格排序
    int get_node();//计数总数
    void print();//打印操作
};

void Link::create_node()
{
    Node *pnew;
    head = new Node;
    //cout<<"请按顺序输入图书的ISBN,书名,定价";
    head->ISBN = 0;
    head->name = 'n';
    head->price = 0;
    head->next = NULL;
    Node *ptemp = head;
    for(int i=0;i<number;i++)
    {
        pnew = new Node;
        cout<<endl;
        cout<<"请按顺序输入图书的ISBN,书名,定价:";
        cin>>pnew->ISBN>>pnew->name>>pnew->price;
        pnew->next = NULL;
        ptemp->next = pnew;
        ptemp = pnew;
    }
}

//按编号查找
int Link::find_node(int i)
{
    Node *ptemp = head->next;
    for(int count = 0;count<number;count++)
        {
            if(ptemp->ISBN == i)//按编号查找图书
            {
                cout<<"图书的编号为:"<<ptemp->ISBN<<"     书名为:"<<ptemp->name<<"       定价为:"<<ptemp->price<<endl;
                return 1;
            }
            ptemp = ptemp->next;
        }
        return 0;
}

//按照书名查找
int Link::find_node(string n)
{
    Node *ptemp = head->next;
    for(int count=0;count<number;count++)
        {
            if(ptemp->name == n)
            {
                cout<<"图书的编号为:"<<ptemp->ISBN<<"     书名为:"<<ptemp->name<<"       定价为:"<<ptemp->price<<endl;
                return 1;
            }
            ptemp = ptemp->next;
        }
        return 0;
}

//按照价格查找
int Link::find_node(float p)
{
    Node *ptemp = head->next;
    for(int count=0;count<number;count++)
        {
            if(ptemp->price == p)
            {
                cout<<"图书的编号为:"<<ptemp->ISBN<<"     书名为:"<<ptemp->name<<"       定价为:"<<ptemp->price<<endl;
                return 1;
            }
            ptemp = ptemp->next;
        }
    return 0;
}

//插入
int Link::insert_node(int pos)
{
    if((pos > number)||(pos<0))
    {
        cout<<"插入位置错误!"<<endl;
        return 0;
    }
    else
    {
        Node *ptemp = head,*pnew;
        for(int i=0;i<pos-1;i++)
        {
            ptemp = ptemp->next;
        }
        pnew = new Node;
        cout<<"请按顺序输入图书的ISBN,书名,价格:";
        cin>>pnew->ISBN>>pnew->name>>pnew->price;
        pnew->next = ptemp->next;
        ptemp->next = pnew;
        number += 1;
    }
    return 1;

}

//删除
int Link::delete_node(int d)
{
    if((d > number)||(d<0))
    {
        cout<<"删除位置错误!"<<endl;
        return 0;
    }
    else
    {
        Node *ptemp = head,*pdelete;
        for(int i=0;i<d-1;i++)
        {
            ptemp = ptemp->next;
        }
        pdelete = ptemp->next;
        ptemp->next = pdelete->next;
        delete pdelete;
        number -= 1;
    }
    return 1;
}

//修改
int Link::mod_node(int d)
{
    int aa;
    string bb;
    float cc;
    if((d > number)||(d<0))
    {
        cout<<"要修改的位置错误!"<<endl;
        return 0;
    }
    else
    {
        Node *ptemp = head->next;
        for(int i=0;i<d-1;i++)
        {
            ptemp = ptemp->next;
        }
        cout<<"要修改编号请输入0,要修改书名请输入1,要修改价格请输入2:";
        int k;
        cin>>k;
        switch(k)
        {
        case 0:
            cout<<"请输入要修改的编号:";
            cin>>aa;
            ptemp->ISBN = aa;
            cout<<endl;
            break;
        case 1:
            cout<<"请输入要更改的书名:";
            cin>>bb;
            ptemp->name = bb;
            cout<<endl;
            break;
        case 2:
            cout<<"请输入要更改的价格:";
            cin>>cc;
            ptemp->price = cc;
            cout<<endl;
            break;
        }
    }
    return 1;
}

//按编号排序
void Link::sort_node_ISBN()
{
    Node *ptemp = head->next,*pre;
    Node *pr = ptemp->next;
    ptemp->next = NULL;
    ptemp = pr;
    while(ptemp != NULL)
    {
        pr = ptemp->next;
        pre = head;
        while(pre->next != NULL && pre->next->ISBN > ptemp->ISBN)
        {
            pre = pre->next;
        }
        ptemp->next = pre->next;
        pre->next = ptemp;
        ptemp = pr;
    }
    Link::print();
}

//按照价格排序
void Link::sort_node_price()
{
    Node *ptemp = head->next,*pre;
    Node *pr = ptemp->next;
    ptemp->next = NULL;
    ptemp = pr;
    while(ptemp != NULL)
    {
        pr = ptemp->next;
        pre = head;
        while(pre->next != NULL && pre->next->price > ptemp->price)
        {
            pre = pre->next;
        }
        ptemp->next = pre->next;
        pre->next = ptemp;
        ptemp = pr;
    }
     Link::print();
}

//获取长度
int Link::get_node()
{
    return number;
}

//打印输出
void Link::print()
{
    Node *ptemp = head->next;
    for(int k=0;k<number;k++)
    {
        cout<<"图书编号:"<<ptemp->ISBN<<"       书名为:"<<ptemp->name<<"       价格为:"<<ptemp->price<<endl;
        ptemp = ptemp->next;
    }
}

//功能函数
void Link::select()
{
    int a;//ISBN
    string b;//书名
    float c;//定价
    int d;//位置
    int p;//选择功能
    cin>>p;
    switch(p)
    {
    case 0:
        cout<<"请输入图书的编号";
        cin>>a;
        if(this->find_node(a))
        {
            cout<<endl;
        }
        else
            cout<<"该图书不存在!"<<endl;
        break;
    case 1:
        cout<<"请输入图书的名字:";
        cin>>b;
        if(this->find_node(b))
        {
            cout<<endl;
        }
        else
            cout<<"该图书不存在!"<<endl;
        break;
    case 2:
        cout<<"请输入图书的价格:";
        cin>>c;
        if(this->find_node(c))
        {
            cout<<endl;
        }
        else
            cout<<"该图书不存在!"<<endl;
        break;
    case 3:
        cout<<"请输入要插入的位置:";
        cin>>d;
        if(this->insert_node(d))
        {
            cout<<"插入操作的结果为:"<<endl;
            this->print();//打印插入结果
        }
        break;
    case 4:
        cout<<"请输入要删除的位置:";
        cin>>d;
        if(this->delete_node(d))
        {
            cout<<"删除操作的结果为:"<<endl;
            this->print();//打印插入结果
        }
        break;
    case 5:
        cout<<"请输入要修改的图书的位置:";
        cin>>d;
        if(this->mod_node(d))
        {
            cout<<"修改后的结果为:"<<endl;
            this->print();
        }
        break;
    case 6:
        cout<<"按照图书的编号进行排序的结果为:"<<endl;
        this->sort_node_ISBN();
        break;
    case 7:
        cout<<"按照图书的价格进行排序的结果为:"<<endl;
        this->sort_node_price();
        break;
    case 8:
        cout<<"当前馆内的图书数量为:";
        cout<<this->get_node();
        break;
    }
}


int main()
{
    int sele=1;//功能选择
    int i;//最开始的数量
    cout<<"请输入你要输入的图书的数量:";
    cin>>i;
    Link l(i);
    l.create_node();
    cout<<endl;
    cout<<"0---------------------为查找(按编号)"<<endl;
    cout<<"1---------------------为查找(按书名)"<<endl;
    cout<<"2---------------------为查找(按定价)"<<endl;
    cout<<"3---------------------为插入"<<endl;
    cout<<"4---------------------为删除"<<endl;
    cout<<"5---------------------为修改"<<endl;
    cout<<"6---------------------为按照图书编号排序"<<endl;
    cout<<"7---------------------为按照图书的价格排序"<<endl;
    cout<<"8---------------------为显示当前馆内的图书总数"<<endl;
    cout<<"请输入要选择的功能:";
    while(sele == 1)
    {
        l.select();
        cout<<"是否要退出管理系统?(输入0退出、输入1继续)";
        cin>>sele;
        cout<<"请输入要选择的功能:";
    }
    cout<<"-----------已退出图书管理系统------------";
    return 0;
}

4.效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 利用C++11原子量如何实现自旋锁详解

    利用C++11原子量如何实现自旋锁详解

    当自旋锁尝试获取锁时以忙等待(busy waiting)的形式不断地循环检查锁是否可用,下面这篇文章主要给大家介绍了关于利用C++11原子量如何实现自旋锁的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-06-06
  • 内联函数inline与宏定义深入解析

    内联函数inline与宏定义深入解析

    类的内敛函数是一个真正的函数。使用内联函数inline可以完全取代表达式形式的宏定义
    2013-09-09
  • C++使用链表存储实现通讯录功能管理

    C++使用链表存储实现通讯录功能管理

    这篇文章主要为大家详细介绍了C++使用链表存储实现通讯录功能管理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • 浅谈C++内存管理基础知识

    浅谈C++内存管理基础知识

    这篇文章主要为大家介绍了C++的内存管理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-11-11
  • C++深入探究list的模拟实现

    C++深入探究list的模拟实现

    list相较于vector来说会显得复杂,它的好处是在任意位置插入,删除都是一个O(1)的时间复杂度,本文主要介绍了C++中List的模拟实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 基于QT的TCP通信服务的实现

    基于QT的TCP通信服务的实现

    在项目开发过程中,很多地方都会用到TCP通信,本文主要介绍了基于QT的TCP通信服务的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • C++运算符重载与多继承及二义性详解

    C++运算符重载与多继承及二义性详解

    继友元知识过后,就到了今天的C++运算符重载的内容了,运算符重载是C++里比较重要的内容。这篇博文不会一下子讲完各种运算符重载,因为太多了了也不好吸收掌握,所以运算符重载我准备分多次记录和分享,那么接下来进入正文
    2022-11-11
  • C语言编程中分配内存空间的相关函数

    C语言编程中分配内存空间的相关函数

    这篇文章主要介绍了C语言编程中分配内存空间的相关函数,分别是malloc()函数和calloc()函数,需要的朋友可以参考下
    2015-08-08
  • Qt控件之QToolButton的使用及示例

    Qt控件之QToolButton的使用及示例

    QToolButton类提供了一个快速访问命令或选项的按钮,通常在QToolBar内部使用,本文主要介绍了Qt控件之QToolButton的使用及示例,感兴趣的可以了解一下
    2023-10-10
  • C语言并查集的非递归实现详解

    C语言并查集的非递归实现详解

    以下是对C语言并查集的递归实现与非递归实现代码进行了详细的介绍,需要的朋友可以过来参考下,希望能够给你带来帮助
    2021-09-09

最新评论