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; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
字符串拷贝函数memcpy和strncpy以及snprintf 的性能比较
以下是对字符串拷贝函数memcpy和strncpy以及snprintf它们之间的性能进行了比较,需要的朋友可以过来参考下2013-07-07
最新评论