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++的数据类型你真的了解吗

    C++的数据类型你真的了解吗

    这篇文章主要为大家详细介绍了C++的数据类型,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • C++有限状态机实现详解

    C++有限状态机实现详解

    这篇文章主要为大家详细介绍了C++有限状态机的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • opencv实现视场转换

    opencv实现视场转换

    这篇文章主要为大家详细介绍了opencv实现视场转换,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • C++ min/max_element 函数用法详解

    C++ min/max_element 函数用法详解

    这篇文章主要介绍了C++ min/max_element 函数用法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • C语言递归应用实现扫雷游戏

    C语言递归应用实现扫雷游戏

    这篇文章主要为大家详细介绍了C语言递归应用实现扫雷游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • Qt QStandardItemModel用法小结

    Qt QStandardItemModel用法小结

    QStandardItemModel可用作标准Qt数据类型的存储库,本文主要介绍了Qt QStandardItemModel用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • C语言素数(质数)判断的3种方法举例

    C语言素数(质数)判断的3种方法举例

    这篇文章主要给大家介绍了关于C语言素数(质数)判断的3种方法,质数是只能被1或者自身整除的自然数(不包括1),称为质数,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-11-11
  • 解决VC++编译报错error C2248的方案

    解决VC++编译报错error C2248的方案

    这篇文章主要介绍了解决VC++编译报错error C2248的方案的相关资料,需要的朋友可以参考下
    2015-11-11
  • C++依赖倒转原则和里氏代换原则有什么好处

    C++依赖倒转原则和里氏代换原则有什么好处

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。本篇介绍设计模式七大原则之一的依赖倒转原则
    2023-02-02
  • C语言实现带头双向循环链表的接口

    C语言实现带头双向循环链表的接口

    这篇文章主要为大家详细介绍了C语言实现带头双向循环链表的接口,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10

最新评论