根据三的分析与描述,主要问题在于:
* 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("%5dt%st%5.0ft%5dt%5dt%5dt%10.0fn",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; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持<计算机技术网(www.ctvol.com)!!>。
—-想了解C++实现商品管理程序分享!全部内容且更多的C语言教程关注<计算机技术网(www.ctvol.com)!!>
本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。
ctvol管理联系方式QQ:251552304
本文章地址:https://www.ctvol.com/c-cdevelopment/483513.html