收藏 分销(赏)

C语言程序设计销售标准管理系统.docx

上传人:w****g 文档编号:2993112 上传时间:2024-06-12 格式:DOCX 页数:30 大小:68.10KB
下载 相关 举报
C语言程序设计销售标准管理系统.docx_第1页
第1页 / 共30页
C语言程序设计销售标准管理系统.docx_第2页
第2页 / 共30页
C语言程序设计销售标准管理系统.docx_第3页
第3页 / 共30页
C语言程序设计销售标准管理系统.docx_第4页
第4页 / 共30页
C语言程序设计销售标准管理系统.docx_第5页
第5页 / 共30页
点击查看更多>>
资源描述

1、 销售信息管理系统设计文档 组号:第二组 组员:汪品高 齐瑞智 欧阳鑫 赵飞锋 章森 目录一 题目和要求二 功效实现设计(模块化设计)三 运行结果(附带抓图)四 源程序 汇报正文1、 题目和要求:2、 某企业有四个销售员(编号:1-4),负责销售五种产品(编号:1-5)。每个销售员汇总当日出售每种产品销售情况。2 天天销售情况包含(销售员代号、产品代号、这种产品当日销售额)1、 编写一个销售信息管理系统,读取上个月销售情况1、 计算上个月没人每种产品销售额2、 按销售额对销售员进行排序,输出排序结果(销售员代号)3、 统计每种产品总销售额,对这些产品从高到低次序输出结果(须输出产品代号和销售额

2、)4、 输出统计报表2、需求分析 本程序将用到文件系统E:/54321.doc文件内容作为数据源,其中单行内容代表一张纸条。程序运行后首先将文件系统原始数据读取并保留到程序结构体数组当中,所以应提供文件输入操作;因为纸条数据零碎,所以要对原始数据进行分类操作并提供一个数组用于保留分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功效选择。3、功效实现设计3.1总体设计依据上面分析,能够将这个系统分为以下五大模块:查看每人每种产品销售额 、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出。其中关键模块是前四个模块。开始3.2步骤图推

3、出系统读取便条上信息3.3具体设计: 3.3.1【头文件和预定义】#include#include主菜单#include#include#define M3.3.2【功效函数申明】vvoid detail();void foreach();输出统计表统计总销售额并排序销售员销售业绩排序每个人每种产品销售额void menu();void product();void readdata();void seller();void total();选择void choice();退出系统返回主菜单3.3.3【数据结构】原始数据有销售员代号、产品代号和销售额,所以定义一个全局结构体数组scrip用于保

4、留原始数据。然后定义全局变量n保留纸条数目,定义数组s用于保留分类后信息。struct ssint sid; /销售员代号int pid; /产品代号int sn; /销售额 ssM; int n; /纸条数目 int s45=0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0; /用于保留职员和产品信息3.3.4【主函数】显示程序设计者相关信息和调用文件读取函数、数据初始化函数和主菜单函数void main() /入口函数,即主函数readdata(); /读取文件数据foreach(); /依据文件初始数据初始化便于操作数组menu(); /显示主菜单3.3.4

5、-1【文件读取函数】readdata()读出便条中内容,并保留到文件结构体中void readdata() /从文件读取数据FILE *fp; /定义文件指针if(fp=fopen(list.txt,r)=NULL)printf(Cant open the file!n);exit(0);else for(n=0;!feof(fp);n+)fscanf(fp,%d %d %dn,&ssn.sid,&ssn.pid,&ssn.sn); /保留文件数据到结构体fclose(fp);3.3.4-2【文件读取函数】foreach()将保留到结构体中信息按产品分类,再依据销售员进行分类,将信息存到数组当

6、中。 void foreach() /从纸条读取数据并分类整理int i;for(i=0;in;i+) /遍历全部纸条switch(ssi.pid) /按产品分大类(比如就是case1-5),依据大类分销售员小类,累加各人各产品销售数量 case 1: switch(ssi.sid) case 1:s00+=ssi.sn;break; case 2:s10+=ssi.sn;break; case 3:s20+=ssi.sn;break; case 4:s30+=ssi.sn;break; break; case 2: switch(ssi.sid) case 1:s01+=ssi.sn;bre

7、ak; case 2:s11+=ssi.sn;break; case 3:s21+=ssi.sn;break; case 4:s31+=ssi.sn;break; break; case 3: switch(ssi.sid) case 1:s02+=ssi.sn;break; case 2:s12+=ssi.sn;break; case 3:s22+=ssi.sn;break; case 4:s32+=ssi.sn;break; break; case 4:switch(ssi.sid) case 1:s03+=ssi.sn;break; case 2:s13+=ssi.sn;break; c

8、ase 3:s23+=ssi.sn;break; case 4:s33+=ssi.sn;break; break; case 5: switch(ssi.sid) case 1:s04+=ssi.sn;break; case 2:s14+=ssi.sn;break; case 3:s24+=ssi.sn;break; case 4:s34+=ssi.sn;break; ; break; 3.3.4-3【主菜单函数】menu()显示系统功效菜单以供用户选择相关功效使用,依据用户选择分别可调用detail():计算上个月每个人每种产品销售额seller():按销售额对销售员进行排序,输出排序结果(

9、销售员代号)product():统计每种产品总销售额,对这些产品按从高到低次序输出排序结果(需输出产品代号和销售额)exit(0):退出系统 void menu()int w,c;do puts(tt*菜单*nn); puts(tt 1.查看每人每种产品销售额n); puts(tt 2.按销售额对销售员排序(销售员代号)n); puts(tt 3.对每种产品总销售额从高到低排序(产品代号和销售额)n); puts(tt 4.输出统计报表n); puts(tt 5.退出n); puts(nntt*n); printf(请选择(1-5): bb); scanf(%d,&c); if(c5) /错误

10、输入则重新获取输入 w=1 else w=0; while(w=1); switch(c) /依据输入实现对应函数调用 case 1: detail();break;/每个销售员每种产品销售额统计 case 2: seller();break; case 3: product();break; case 4: total();break; case 5: exit(0); 3.3.5【功效函数】5-1【每人每种产品销售额统计函数】detail() 计算上个月每个人每种产品销售额void detail() /显示销售情况int i,j; for(i=0;i4;i+) /遍历销售员printf(n

11、tt%d号销售员销售情况:n,i+1); for(j=0;j5;j+) /按销售员分类遍历全部产品并显示信息 printf(tt%d号产品销售数量:%dn,j+1,sij); choice();3.3.5-1【销售员销售业绩排序函数】seller()按销售额对销售员进行排序,输出排序结果(销售员代号)void seller()int i,j,k;int sp4=0,0,0,0;for(i=0;i4;i+)for(j=0;j5;j+)spi+=sij; /计算每单个销售员全部产品销售数量for(i=0;i4;i+) /比较四次,每次选出最大数 k=0; /用于标识单轮最大数for(j=0;j4;

12、j+)if(spkspj)k=j; /获取最大数标号printf(tt第%d名是%d号销售员!n,i+1,k+1);spk=-1; /输出最大数和排名,将最大数标识为负choice();3.3.5-2【总销售额统计函数】void product()统计每种产品总销售额,对这些产品按从高到低次序输出排序 void product() /和seller()原理一样,用于对产品进行统计 int i,j,k;int p5=0,0,0,0,0;for(j=0;j5;j+)for(i=0;i4;i+)pj+=sij;for(j=0;j5;j+) k=0;for(i=0;i5;i+)if(pkpi)k=i;

13、printf(tt第%d名是%d号产品!t销量为%d!n,j+1,k+1,pk);pk=-1;choice();3.3.5-3【统计报表输出函数】total()统计每种产品总销售额,对这些产品按从高到低次序输出排序结果(需输出产品代号和销售额)void total() /输出报表 int i,j;printf(nt销售员t产品t销量n);for(i=0;i4;i+)for(j=0;j返回菜单t2退出系统 bb);scanf(%d,&c);if(c=1)menu();elseexit(0);puts(n);4、运行结果(附带抓图)List.txt(便条)文件中数据以下:(提前建立文件或就将便条保

14、留在文件中! )1 1 11 2 21 3 31 4 81 5 92 1 32 2 32 3 42 4 52 5 63 1 13 2 1 (这是个例子)3 3 43 4 53 5 64 1 24 2 34 3 44 4 54 5 6运行结果 显示主菜单: 查看每人每种产品销售额运行结果:按销售额对销售员按次序排序(销售员代号)运行结果对每种产品销售额从高到低排序运行结果:统计报表运行结果:6、源程序#include #include#include /*调用exit函数*/#include#define M 155 /*宏定义*/void detail();void foreach();voi

15、d menu();void product();void readdata();void seller();void total();void choice();struct ssint sid; /销售员代号int pid; /产品代号int sn; /销售额 ssM; int n; /纸条数目 int s45=0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0; /用于保留职员和产品信息void main() /入口函数,即主函数 p readdata(); /读取文件数据 foreach(); /依据文件初始数据初始化便于操作数组 menu(); /显示主菜单

16、void readdata() /从文件读取数据FILE *fp;if(fp=fopen(list.txt,r)=NULL)printf(Cant open the file!n);exit(0);else for(n=0;!feof(fp);n+)fscanf(fp,%d %d %dn,&ssn.sid,&ssn.pid,&ssn.sn); /保留文件数据到结构体fclose(fp); void foreach() /从纸条读取数据并分类整理int i;for(i=0;in;i+) /遍历全部纸条switch(ssi.pid) /按产品分大类,依据大类分销售员小类,累加个人各产品销售数量 c

17、ase 1: switch(ssi.sid) case 1:s00+=ssi.sn;break; case 2:s10+=ssi.sn;break; case 3:s20+=ssi.sn;break; case 4:s30+=ssi.sn;break; break; case 2: switch(ssi.sid) case 1:s01+=ssi.sn;break; case 2:s11+=ssi.sn;break; case 3:s21+=ssi.sn;break; case 4:s31+=ssi.sn;break; break; case 3: switch(ssi.sid) case 1:

18、s02+=ssi.sn;break; case 2:s12+=ssi.sn;break; case 3:s22+=ssi.sn;break; case 4:s32+=ssi.sn;break; break; case 4:switch(ssi.sid) case 1:s03+=ssi.sn;break; case 2:s13+=ssi.sn;break; case 3:s23+=ssi.sn;break; case 4:s33+=ssi.sn;break; break; case 5: switch(ssi.sid) case 1:s04+=ssi.sn;break; case 2:s14+=

19、ssi.sn;break; case 3:s24+=ssi.sn;break; case 4:s34+=ssi.sn;break; ; break; void menu()int w,c;do puts(tt*菜单*nn); puts(tt 1.查看每人每种产品销售额n); puts(tt 2.按销售额对销售员排序(销售员代号)n); puts(tt 3.对每种产品总销售额从高到低排序(产品代号和销售额)n); puts(tt 4.输出统计报表n); puts(tt 5.退出n); puts(nntt*n); printf(请选择(1-5): bb); scanf(%d,&c); if(c5)

20、 /错误输入则重新获取输入 w=1; getchar(); else w=0; while(w=1); switch(c) /依据输入实现对应函数调用 case 1: detail();break;/每个销售员每种产品销售额统计 case 2: seller();break; case 3: product();break; case 4: total();break; case 5: exit(0); void detail() /显示销售情况int i,j; for(i=0;i4;i+) /遍历销售员printf(ntt%d号销售员销售情况:n,i+1); for(j=0;j5;j+) /

21、按销售员分类遍历全部产品并显示信息 printf(tt%d号产品销售数量:%dn,j+1,sij); choice();void seller()int i,j,k;int sp4=0,0,0,0;for(i=0;i4;i+)for(j=0;j5;j+)spi+=sij; /计算每单个销售员全部产品销售数量for(i=0;i4;i+) /比较四次,每次选出最大数 k=0; /用于标识单轮最大数for(j=0;j4;j+)if(spkspj)k=j; /获取最大数标号printf(tt第%d名是%d号销售员!n,i+1,k+1);spk=-1; /输出最大数和排名,将最大数标识为负choice(

22、); void product() /和seller()原理一样,用于对产品进行统计 int i,j,k;int p5=0,0,0,0,0;for(j=0;j5;j+)for(i=0;i4;i+)pj+=sij;for(j=0;j5;j+)k=0;for(i=0;i5;i+)if(pkpi)k=i;printf(tt第%d名是%d号产品!t销量为%d!n,j+1,k+1,pk);pk=-1;choice();void total() /输出报表 int i,j;printf(nt销售员t产品t销量n);for(i=0;i4;i+)for(j=0;j返回菜单t2退出系统 bb);scanf(%d,&c);if(c=1)menu();elseexit(0);puts(n);

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 通信科技 > 开发语言

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服