C++实现商品管理程序

本文实例为大家分享了C++商品管理程序的具体代码,供大家参考,具体内容如下

一、题目:商品管理程序

二、目的与要求

1.目的

培养学生综合利用C++语言进行程序设计的能力,培养学生综合利用C++语言进行程序设计的能力,熟悉数组的操作,加强函数的运用,掌握典型算法的使用,提高软件系统分析能力和程序文档建立、归纳总结的能力。

2.基本要求

(1) 要求用C++语言编程,在Visual C++环境下调试完成;
(2) 要求按照程序功能分成几个功能模块来实现,各个功能模块分别使用函数来完成;
(3) 要求提供操作菜单,以便用户进行选择;
(4) 应对程序添加必要的注释;
(5) 要求应用本课所讲授的程序设计语言知识来解决问题,使用教材前六章的内容来完成程序。

3.创新要求

在基本要求达到后,进行创新设计:

(1) 对程序功能进行拓展,使其更加实用。例如增加删除功能和插入功能,即找到指定商品后将其从原数组中删除;将新商品的信息按照商品代码升序的顺序插入到原数组中。

三、设计方法和基本原理

1.1功能描述

编写一个简单的商品信息管理程序,主要完成商品的一些信息的计算,商品的排序、查询及显示功能。
问题详细描述
某商场的电器区有多种商品,每种商品包括以下信息:
代码(整型),名称(字符串),总量(整型),单价(双精度),销售量(整型),库存量(=总量-销售量,整型),销售额(销售量*单价,双精度),例如目前有五种商品的基本信息,如表1所示。

--------------------------------------表1 商品信息列表-----------------------------------------------

要求在主函数中对各类商品的信息进行初始化,编写多个函数分别实现下列功能,而后在main函数中进行调用。
各个函数的功能描述为:

(1) 计算函数cal:计算各类商品的库存量及销售额。
(2) 排序函数sort1:按库存量升序排序,若库存量相同则按销售量升序排序,要求使用冒泡法排序。
(3) 排序函数sort2:按商品名称降序排序,要求使用选择法排序。
(4) 查询函数search:根据商品代码查找指定商品。若找到则返回该商品的下标,否则返回-1。
(5) 汇总函数total:计算并返回销售总额(所有商品的销售额的和)。
(6) 显示函数output:输出商品的信息。
(7) 显示菜单函数showMenu:显示菜单。

下面给出程序运行的部分界面:

(1) 程序首先计算库存量与销售额,而后显示菜单,提示用户输入数字1~6以进行对应操作,运行界面如图1所示。

(2)若用户输入的菜单选项不满足要求(未在1~6范围内),则给出提示信息,提示用户重新输入,直到用户输入正确选项,运行界面如图2所示。
(3) 当用户输入正确菜单选项时,则调用对应函数,运行界面如图3所示(执行菜单项1与5后的界面)、图4(执行菜单项3后的界面)。

(4) 当用户输入6时,结束程序执行,否则将一直提示用户进行输入。

1. 2. 问题的解决方案

根据问题的描述,为实现程序的功能,可按照下述过程完成程序(仅供参考,可自行设计实现过程及方法):
* (1) 在主函数中定义结构体数组存储五种商品的信息,并使用给出的数据对该数组进行初始化,而后调用cal函数进行计算。
* (2) 为方便用户选择,应提供良好的操作界面供用户使用,根据不同的要求进入到对应的功能模块。执行完某个功能后,应重新显示菜单,因此可定义显示菜单函数showMenu,并将该函数的调用置于循环结构中。
* (3) 为实现根据用户的不同输入(共6个)调用对应函数,应采用多分支结构,可使用switch语句或else if语句实现。为实现多次输入,应将将菜单的显示、用户对菜单选项的输入及各个功能模块的调用置于一个循环结构,当输入为6时,结束该循环。
* (4) 输入待查找商品的代码,再调用查找函数search进行查找,若找到,调用output函数输出该商品的信息,否则输出未找到的提示信息。

四、主要技术问题的描述

根据三的分析与描述,主要问题在于:
* 1. 结构体类型的构造(struct PRO)
为表示商品的完整信息,该类型应包括以下成员:代码(int code)、名称(char name[20]) ,总量(int amount) ,单价(double price),销售量(int sale1),商品的库存量(int stock),销售额(double sale2)。
* 2. 函数的参数传递问题
由于该程序是对结构体数组的操作,因此使用传递地址的方法,并传递数组长度。以查找函数为例,该函数的原型说明语句为:int search(PRO s[],int n ,int x); ,即在长度为n的s数组中查找代码为x的商品,若找到,则返回该商品的下标,否则返回-1。形参分别表示结构体数组,数组长度及待查商品的代码。
* 3. 查询后如何调用output函数只输出一种商品的信息
已知output函数的原型说明语句为: void output(PRO s[],int n); ,因此若要输出下标为k的一个商品的信息, 调用形式应为:output(s+k, 1); ,其中,s为结构体数组名,k为调用查询函数search后返回的商品下标,1表示输出商品的个数。

程序源代码

#include <iostream>
using namespace std;
void showMenu()
{
  cout<<"***************************"<<endl;
  cout<<"请输入1~6内的数字"<<endl;
  cout<<"1  按照库存量升序排序\n";
  cout<<"2  按照商品名称降序排序\n";
  cout<<"3  查找指定代码的商品信息\n";
  cout<<"4  计算销售总额\n";
  cout<<"5  输出商品的信息\n";
  cout<<"6  结束\n";
  cout<<"***************************"<<endl;
}
struct PRO
{
  int code;//代码
  char name[20];//名称
  int amount;//总量
  double price;//单价
  int sale1;//销售量
  int stock;//商品库存量
  double sale2;//销售额
};
void cal(struct PRO s[],int n)//计算函数
{
  for(int i=0;i<n;i++)
  {
    s[i].stock=s[i].amount-s[i].sale1;
    s[i].sale2=s[i].sale1*s[i].price;
  }
}

void sort1(struct PRO s[],int n)//按库存量升序(小到大)排序,若库存量相同则按销售量升序排序,要求使用冒泡法排序。
{
  for(int i=0;i<n-1;i++)//比较n-1轮
  {
    for(int j=0;j<n-i-1;j++)//每轮比较n-1-i次
    {
      if(s[j].stock>s[j+1].stock||(s[j].stock==s[j+1].stock&&s[j].sale1>s[j+1].sale1))
      {
        PRO a;
        a=s[j];
        s[j]=s[j+1];
        s[j+1]=a;
      }
    }
  }
}

void sort2(struct PRO s[],int n)//按商品名称降序排序,要求使用选择法排序。

{
  for(int i=0;i<n;i++)
  {  int max=i;
    for(int j=i+1;j<n;j++)
    {
      if(strcmp(s[j].name, s[max].name)>0)max=j;
    }
    PRO temp;
    temp=s[i];
    s[i]=s[max];
    s[max]=temp;
  }
}

double total(PRO s[],int n)//计算并返回销售总额(所有商品的销售额的和)。
{
  double sum=0;
  for(int i=0;i<n;i++)
  {
    sum+=s[i].sale2;
  }
  return sum;
}

int search(PRO s[],int n,int x)
{
  for(int i=0;i<n;i++)
  {
    if(x==s[i].code)
    {
      return i;
    }
  }
  return -1;
}
void output(struct PRO s[],int n)
{
  cout<<"代码   名称     单价   总量  销售量  库存量   销售额\n";
  for(int i=0;i<n;i++)
  {
    printf("%5d\t%s\t%5.0f\t%5d\t%5d\t%5d\t%10.0f\n",s[i].code,s[i].name,s[i].price,s[i].amount,s[i].sale1,s[i].stock,s[i].sale2);
  }
}
int main(int argc, const char * argv[]) {
  int C;
  struct PRO s[5]=  //商品信息初始化
  {
    {10120,"HaierCon",155,2998,55,0,0},
    {10564,"IPod MP3",245,1250,32,0,0},
    {11254,"SegaHDisk",120,655,20,0,0},
    {15826,"IBMLaptop",80,8188,15,0,0},
    {18257,"SonyDigtC",150,3588,29,0,0}
  };
  showMenu();
  cal(s, 5);
  while(cin>>C)
  {
    if(C<1|C>6){cout<<"输入错误,请输入1~6范围内的数字"<<endl;continue;}
    else
    {
      switch (C) {
        case 1:
        { cout<<"按库存量升序排序,请等待....\n";
         sort1(s, 5);
         cout<<"排序结束.\n";
         break;
        }
        case 2:
        {
          cout<<"按商品名称降序排序,请等待....\n";
          sort2(s, 5);
          cout<<"排序结束.\n";
          break;
        }
        case 3:
        {  int x;
          cout<<"请输入指定商品的代码:\n";
          cin>>x;
          if(search(s,5,x)==-1)
          {
            cout<<"未找到,没有该种商品!"<<endl;
          }
          else
          {
            cout<<"找到改商品,其信息为:"<<endl;
            output(s+search(s,5,x),1);
          }
          break;
        }
        case 4:
          cout<<"销售总额为:"<<total(s, 5)<<endl;
          break;
        case 5:
          output(s, 5);
          break;
        case 6:
          exit(0);
          break;
      }
    }
    showMenu();
  }
  return 0;
}

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

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。