返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++顺序表实现图书管理系统
  • 171
分享到

C++顺序表实现图书管理系统

2024-04-02 19:04:59 171人浏览 独家记忆
摘要

本文为大家分享了c++顺序表实现图书管理系统的具体代码,供大家参考,具体内容如下 图书信息表包括以下10项常用的基本操作:图书信息表的创建和输出、排序、修改、逆序存储、最贵图书的查找

本文为大家分享了c++顺序表实现图书管理系统的具体代码,供大家参考,具体内容如下

图书信息表包括以下10项常用的基本操作:图书信息表的创建和输出、排序、修改、逆序存储、最贵图书的查找、最爱图书的查找、最佳位置图书的查找、新图书的入库、旧图书的出库、图书去重。

代码:


#include<iOStream>
#include<iomanip>
#include<string>
using namespace std;
//函数结果状态代码
#define OK 1
#define ERROR 0
#define OVERFLOW -2
//Status是函数返回值类型,其值是函数结果状态代码 
typedef int Status; 
#define MAXSIZE 100
struct BOOK
{
 string ib;//isbn
 string name;//名字 
 float price;//价格 
};
typedef struct
{
 BOOK *elem;//存储空间的基地址 
 int length; //当前长度 
} sqlist;
//1、创建一个图书信息表 
Status CreateTheList(SqList &L)
{
 L.elem = new BOOK[MAXSIZE];//为顺序表分配一个大小为MAXSIZE的数组空间 
 if(!L.elem) exit(OVERFLOW);//存储分配失败退出 
 L.length = 0;//将长度初始化为0 
 return OK;
}
//3.根据图书价格对图书信息表进行降序排序
Status SortTheList(SqList &L)
{
 //让每一个数据与其后面的价格都进行对比,若价格小于其后面的便进行交换,以保证价格小的在后面 
    for(int i=0;i<L.length;++i)
 {
        for(int j=i+1;j<L.length;++j)
  {
            if(L.elem[i].price<L.elem[j].price)
   {
                BOOK temp;
                temp=L.elem[i];
                L.elem[i]=L.elem[j];
                L.elem[j]=temp;
            }
        }
    }
    cout<<"排序成功"<<endl;
}
//4.修改图书信息表
Status ChangeTheList(SqList &L)
{
 //求平均值 
 float total=0;
 for(int i=0;i<L.length;i++)
 {
  total += L.elem[i].price;
 }
 float ave=total/L.length;
 cout<<"平均价格为:"<<ave<<endl; 
 //修改每本图书的价格 
 for(int i=0;i<L.length;i++)
 {
  if(L.elem[i].price>ave)
   L.elem[i].price *= 1.1;
  else
   L.elem[i].price *= 1.2;
 }
 cout<<"修改成功"<<endl; 
}
//5.实现该图书信息表的逆序存储
Status ReverseTheList(SqList &L)
{
 //将第一个元素与最后一个交换位置,第二个与倒数第二个交换,以此类推 
 for(int i=0;i<L.length/2;i++)
 {
  BOOK temp;
  temp = L.elem[i];
  L.elem[i] = L.elem[L.length-1-i];
  L.elem[L.length-i-1] = temp;
 }
 cout<<"逆序存储成功"<<endl;
}
//6.查找图书信息表中最贵的图书
Status TheExpensiveBook(SqList &L)
{
 //先找最贵的价格 
 float max=0;
 int i,number=0;
 for(i=0;i<L.length;i++)
 {
  if(L.elem[i].price>max)
   max=L.elem[i].price;
 }
 cout<<"图书最贵的价格为:"<<max<<endl;
 //再遍历图书表寻找价格等于max的图书并输出 
 for(i=0;i<L.length;i++)
 {
  if(L.elem[i].price == max)
  {
   number++;
   cout<<setiosflags(ios::fixed);//设置小数点的位数 
   cout<<L.elem[i].ib<<" "<<L.elem[i].name<<" "<<setprecision(2)<<L.elem[i].price<<endl;
  }
 }
 cout<<"最贵的图书数量为:"<<number<<endl; 
}
//7.查找最爱的图书
Status TheFavouriteBook(SqList &L)
{
 int x;
 cout<<"请输入要查找的次数:"<<endl;
 cin>>x;//要找的书的数量 
 for(int i=1;i<=x;i++)
 {
  cout<<"请输入要查找的书名:"<<endl;
  string name1;
  cin>>name1;//输入书名
  int number=0;//记录与输入的书名相同的书的数量
  for(int j=0;j<L.length;j++)
  {
   if(L.elem[j].name == name1)
   {
    number++;
    cout<<setiosflags(ios::fixed);//设置小数点的位数 
    cout<<L.elem[j].ib<<" "<<L.elem[j].name<<" "<<setprecision(2)<<L.elem[j].price<<endl;
   }
  }
  if(number==0)
  {
   cout<<"抱歉,没有你的最爱!"<<endl;
  }
  else
  {
   cout<<"第"<<i<<"次输入的书名对应的书有:"<<number<<"本"<<endl; 
  } 
 }
}
//8.查找最佳位置上的图书
Status TheBestPosition(SqList &L)
{
 int x;
 cout<<"请输入要查找的次数:"<<endl;
 cin>>x;//要查找的次数 
 for(int i=1;i<=x;i++)
 {
  cout<<"请输入要查找的位置:"<<endl;
  int pos;
  cin>>pos;//输入位置 
  if(pos<=0 || pos>L.length)
  {
   cout<<"抱歉,最佳位置上的图书不存在!"<<endl;
  }
  else
  {
   cout<<setiosflags(ios::fixed);//设置小数点的位数 
   cout<<L.elem[pos-1].ib<<" "<<L.elem[pos-1].name<<" "<<setprecision(2)<<L.elem[pos-1].price<<endl;
  }
 }
}
//9.新图书入库
Status InsertABook(SqList &L)
{
 cout<<"输入要插入的位置:"<<endl;
 int x;
 cin>>x;//输入要插入的位置
 //判断位置是否合法 
 if(x<1 || x>L.length+1)
 {
  cout<<"抱歉,入库位置非法!"<<endl;
 }
 else
 {
  cout<<"输入要插入的图书信息:"<<endl;
  string ib1;
  cin>>ib1;
  string name1;
  cin>>name1;
  float price1;
  cin>>price1;
  BOOK e;//e包含要插入的书的信息 
  e.ib = ib1;
  e.name = name1;
  e.price = price1;
  //将插入位置之后的元素后移一位 
  for(int j=L.length-1;j>=x-1;j--)
  {
   L.elem[j+1]=L.elem[j]; 
  }
  L.elem[x-1]=e;//插入元素 
  L.length +=1;//表长加一
  cout<<"插入成功"<<endl;  
 }
}
//10.旧图书出库
Status DeleteABook(SqList &L,int x)
{
 //判断位置是否合法 
 if(x<1 || x>L.length)
 {
  cout<<"抱歉,出库位置非法!"<<endl;
 }
 else
 {
  //被删除元素之后的元素前移一位 
  for(int j=x;j<=L.length-1;j++)
  {
   L.elem[j-1]=L.elem[j]; 
  }
  L.length -=1;//表长减一
  cout<<"删除成功"<<endl;  
 }
}
//11.图书信息表去重
Status DeleteTheRepeat(SqList &L)
{
 int i,j;
 for(i=0;i<L.length;i++)
 {
  for(j=i+1;j<L.length;j++)
  {
   if(L.elem[i].ib == L.elem[j].ib)
   {
    DeleteABook(L,j+1);
    j=j-1;
   }
  }
 }
 cout<<"去重完成"<<endl;
 cout<<"(输出删除成功表示信息表中有重复的书籍存在)"<<endl;
}
//12.输出图书信息表 
Status PrintTheList(SqList &L)
{
 int i=0;
 cout<<"图书的数量为:"<<L.length<<endl;
 for(;i<L.length;i++)
 {
  cout<<setiosflags(ios::fixed);//设置小数点的位数 
  cout<<L.elem[i].ib<<" "<<L.elem[i].name<<" "<<setprecision(2)<<L.elem[i].price<<endl;
 }
}
int main()
 {
  SqList l;
  while(true){
   cout<<"欢迎使用图书管理系统"<<endl;
   cout<<"1.创建一个图书信息表"<<endl;
   cout<<"2.录入图书信息"<<endl;
   cout<<"3.根据图书价格对图书信息表进行降序排序"<<endl;
   cout<<"4.修改图书信息表,修改规则如下:"<<endl; 
  cout<<"计算所有图书的平均价格,将所有低于平均价格的图书价格提高20%,所有高于或等于平均价格的图书价格提高10%,最后打印该表"<<endl;
   cout<<"5.实现该图书信息表的逆序存储"<<endl;
   cout<<"6.查找图书信息表中最贵的图书"<<endl;
   cout<<"7.查找最爱的图书"<<endl;
   cout<<"8.查找最佳位置上的图书"<<endl;
   cout<<"9.新图书入库"<<endl;
   cout<<"10.旧图书出库"<<endl;
   cout<<"11.图书信息表去重"<<endl;
  cout<<"12.输出图书信息表"<<endl;
  cout<<"13.退出系统"<<endl;
  cout<<"请输入您的选择:"<<endl;
  int x,i=0;
  cin>>x;
  switch(x){
   case 1:
    if(CreateTheList(l))
     cout<<"创建成功"<<endl;
    else
     cout<<"创建失败"<<endl; 
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 2:
    cout<<"请输入图书的信息:"<<endl; 
    while(true){
     //输入图书的信息
     string ib1;
     cin>>ib1;
     string name1;
     cin>>name1;
     float price1;
     cin>>price1;
     //判断是不是输入结束 
     if(ib1 =="0" && name1 =="0" && price1 == 0)
     {
      break;
     }
     //向后插入读入的图书信息 
     l.elem[i].ib = ib1;
     l.elem[i].name = name1;
     l.elem[i].price = price1;
     i++;//图书数量加一 
    }
    l.length = i; 
    cout<<"录入完毕"<<endl;
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 3:
    SortTheList(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 4:
    ChangeTheList(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 5:
    ReverseTheList(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 6:
    TheExpensiveBook(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 7:
    TheFavouriteBook(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 8:
    TheBestPosition(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 9:
    InsertABook(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 10:
    cout<<"输入要删除的书籍的位置:"<<endl;
    int x;
    cin>>x;//输入要删除的位置
    DeleteABook(l,x);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 11:
    DeleteTheRepeat(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 12:
    PrintTheList(l);
    cout<<"-------------------------------------------------------------"<<endl;
    break;
   case 13:
    exit(0);   
  }
  }
 }

测试数据:

9787302257646  程序设计基础 25.00

9787302164340  程序设计基础第二版 20.00

9787302219972  单片机技术及应用 32.00

9787302219972  单片机技术及应用 32.00

9787302203513  单片机原理与技术应用 26.00

9787810827430  工业计算机控制技术原理与应用 31.00

9787811234923  汇编语言程序设计教程 21.00

9787811234923  汇编语言程序设计教程 21.00

运行结果:

创建与输出

对图书价格进行降序排序

修改图书价格

实现逆序存储

查找最贵图书

查找最爱的图书

查找最佳位置的图书

新图书入库

旧图书出库

图书信息去重(根据ISBN去重)

去重前书籍信息

去重后

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

--结束END--

本文标题: C++顺序表实现图书管理系统

本文链接: https://lsjlt.com/news/137904.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C++顺序表实现图书管理系统
    本文为大家分享了C++顺序表实现图书管理系统的具体代码,供大家参考,具体内容如下 图书信息表包括以下10项常用的基本操作:图书信息表的创建和输出、排序、修改、逆序存储、最贵图书的查找...
    99+
    2024-04-02
  • Java顺序表实现图书管理系统
    本文实例为大家分享了Java顺序表实现图书管理系统的具体代码,供大家参考,具体内容如下 一、简介 实现此项目的目的是巩固并理解前面的知识点:类,抽象类,封装,继承,多态,接口等 二、...
    99+
    2024-04-02
  • Java顺序表怎么实现图书管理系统
    这篇文章主要讲解了“Java顺序表怎么实现图书管理系统”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java顺序表怎么实现图书管理系统”吧!一、简介实现此项目的目的是巩固并理解前面的知识点:...
    99+
    2023-06-25
  • C#实现图书管理系统
    本文为大家分享了C#实现图书管理系统课程设计,供大家参考,具体内容如下 一、设计目的 通过模拟图书管理系统,实现以下功能学生账号的注册学生对馆藏图书状况的查询学生借书,还书状态的查询...
    99+
    2024-04-02
  • C++使用链表实现图书管理系统
    本文实例为大家分享了vue + element ui实现锚点定位的具体代码,供大家参考,具体内容如下 一、程序实现功能 1.录入书籍:将书籍录入图书管理系统 2.浏览书籍:查看图书管...
    99+
    2024-04-02
  • C++实现图书馆管理系统
    本文实例为大家分享了C++实现图书馆管理系统的具体代码,供大家参考,具体内容如下 一、实验名称 图书馆管理系统 二、实验目的 利用C++语言设计开发一个小型的图书馆管理系统模拟程序,...
    99+
    2024-04-02
  • C语言单链表实现图书管理系统
    本文实例为大家分享了C语言单链表实现图书管理系统的具体代码,供大家参考,具体内容如下 单链表实现的图书管理系统相比于结构体实现的管理系统,可以随时开辟新的空间,可以增加书的信息 单链...
    99+
    2024-04-02
  • C/C++实现图书信息管理系统
    本文实例为大家分享了c/c++实现图书信息管理系统的具体代码,供大家参考,具体内容如下 程序流程图 源代码 #include <stdio.h> #include ...
    99+
    2024-04-02
  • C++编写实现图书管理系统
    C++编写的一个图书管理系统,供大家参考,具体内容如下 2018大一的课设,搬到这纪念一下,共1200多行代码 为图书管理人员编写一个图书管理系统,图书管理系统的设计主要是实现对图书...
    99+
    2024-04-02
  • C++实现图书管理系统源码
    本文实例为大家分享了C++实现图书管理系统的具体代码,供大家参考,具体内容如下 直接上代码 #include <stdafx.h> #include <iostr...
    99+
    2024-04-02
  • C++实现小型图书管理系统
    本文实例为大家分享了C++实现小型图书管理系统的具体代码,供大家参考,具体内容如下 因为课程设计的原因,需要实现一个小型图书管理系统 包含功能: 问题描述: 设计一个系统,对图书信息...
    99+
    2024-04-02
  • C++实现图书信息管理系统
    本文实例为大家分享了C++实现图书信息管理系统的具体代码,供大家参考,具体内容如下 1.题目: 类型有:编号:ISBN书名:name价格:price 完成如下的功能: ①录入:从键盘...
    99+
    2024-04-02
  • C++如何实现图书管理系统
    本文小编为大家详细介绍“C++如何实现图书管理系统”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++如何实现图书管理系统”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。功能:首先是注册,登录,找回密码和修改密码...
    99+
    2023-06-29
  • C#如何实现图书管理系统
    本文小编为大家详细介绍“C#如何实现图书管理系统”,内容详细,步骤清晰,细节处理妥当,希望这篇“C#如何实现图书管理系统”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、设计目的通过模拟图书管理系统,实现以下功能...
    99+
    2023-06-29
  • C语言链表实现简单图书管理系统
    本文实例为大家分享了C语言链表实现图书管理系统的具体代码,供大家参考,具体内容如下 实现功能: 用C语言制作图书管理系统,实现图书进行登记书籍,浏览书籍,借阅书籍,归还书籍,书籍排序...
    99+
    2024-04-02
  • C++如何使用链表实现图书管理系统
    这篇文章主要为大家展示了“C++如何使用链表实现图书管理系统”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C++如何使用链表实现图书管理系统”这篇文章吧。具体内容如下一、程序实现功能录入书籍:将...
    99+
    2023-06-29
  • C++利用链表实现图书信息管理系统
    C++利用链表实现一个简单的图书信息管理系统,供大家参考,具体内容如下 (1)图书信息包括ISBN号、书名、作者名、价格和数量等; (2)系统的主要功能包括:图书信息的创建、输出图书...
    99+
    2024-04-02
  • C++实现图书管理程序
    本文实例为大家分享了C++实现图书管理程序的具体代码,供大家参考,具体内容如下 主文件 #include <iostream> #include "library.h" ...
    99+
    2024-04-02
  • C++实现图书管理系统最新版
    图书管理系统设计,供大家参考,具体内容如下 一、问题描述及功能要求 (1)图书信息录入功能(图书信息用文件保存) (2)图书信息浏览功能 (3)查询和排序功能:(至少一种查询方式) ...
    99+
    2024-04-02
  • C语言实现图书馆管理系统
    本文实例为大家分享了C语言实现图书馆管理系统的具体代码,供大家参考,具体内容如下 全部代码如下: #include <stdio.h> #include<str...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作