服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C++实现商品管理程序

C++实现商品管理程序

2021-08-10 15:55隔壁菜鸡 C/C++

这篇文章主要为大家详细介绍了C++实现商品管理程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

一、题目:商品管理程序

二、目的与要求

1.目的

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

2.基本要求

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

3.创新要求

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

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

三、设计方法和基本原理

1.1功能描述

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

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

C++实现商品管理程序

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

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

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

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

C++实现商品管理程序

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

C++实现商品管理程序

(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表示输出商品的个数。

程序源代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
#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;
}

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

原文链接:https://blog.csdn.net/xsydalao/article/details/91974003

延伸 · 阅读

精彩推荐