ImageVerifierCode 换一换
格式:DOCX , 页数:30 ,大小:68.10KB ,
资源ID:2993112      下载积分:12 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/2993112.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(C语言程序设计销售标准管理系统.docx)为本站上传会员【w****g】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

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

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

2、品当日销售额) 1、 编写一个销售信息管理系统,读取上个月销售情况 1、 计算上个月没人每种产品销售额 2、 按销售额对销售员进行排序,输出排序结果(销售员代号) 3、 统计每种产品总销售额,对这些产品从高到低次序输出结果(须输出产品代号和销售额) 4、 输出统计报表 2、需求分析 本程序将用到文件系统E://54321.doc文件内容作为数据源,其中单行内容代表一张纸条。程序运行后首先将文件系统原始数据读取并保留到程序结构体数组当中,所以应提供文件输入操作;因为纸条数据零碎,所以要对原始数据进行分类操作并提供一个数组用于保留分类信息;在程序中要进行统计工作,所以要提供显示、

3、排序等操作;另外应提供键盘式选择菜单实现功效选择。 3、功效实现设计 3.1总体设计 依据上面分析,能够将这个系统分为以下五大模块:查看每人每种产品销售额 、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出。其中关键模块是前四个模块。 开始 3.2步骤图 推出系统 读取便条上信息 3.3具体设计: 3.3.1【头文件和预定义】 #include #include 主菜单 #include #include #define M 3.3.2【

4、功效函数申明】 vvoid detail(); void foreach(); 输出统计表 统计总销售额并排序 销售员销售业绩排序 每个人每种产品销售额 void menu(); void product(); void readdata(); void seller(); void total(); 选择 void choice(); 退出系统 返回主菜单 3.3.3【数据结构】 原始数据有销售员代号、产品代号和销售额,所以定义一个全局结构体数组scrip用于保留原始数据。然后定义全局变量n保留纸条数目,定义数组s用于保留分类后信息。

5、struct ss { int sid; //销售员代号 int pid; //产品代号 int sn; //销售额 }ss[M]; int n; //纸条数目 int s[4][5]={{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(); //依

6、据文件初始数据初始化便于操作数组 menu(); //显示主菜单 } 3.3.4-1【文件读取函数】readdata() 读出便条中内容,并保留到文件结构体中 void readdata() //从文件读取数据 { FILE *fp; //定义文件指针 if((fp=fopen("list.txt","r"))==NULL) { printf("Can't open the file!\n"); exit(0); } else for(n=0;!feof(fp);n++) {

7、fscanf(fp,"%d %d %d\n",&ss[n].sid,&ss[n].pid,&ss[n].sn); } //保留文件数据到结构体 fclose(fp); } 3.3.4-2【文件读取函数】foreach() 将保留到结构体中信息按产品分类,再依据销售员进行分类,将信息存到数组当中。 void foreach() //从纸条读取数据并分类整理 { int i; for(i=0;i

8、产品分大类(比如就是case1--5),依据大类分销售员小类,累加各人各产品销售数量 { case 1: switch(ss[i].sid) { case 1:s[0][0]+=ss[i].sn;break; case 2:s[1][0]+=ss[i].sn;break; case 3:s[2][0]+=ss[i].sn;break; case 4:s[3][0]+=ss[i].sn;break; } break; case 2:

9、 switch(ss[i].sid) { case 1:s[0][1]+=ss[i].sn;break; case 2:s[1][1]+=ss[i].sn;break; case 3:s[2][1]+=ss[i].sn;break; case 4:s[3][1]+=ss[i].sn;break; } break; case 3: switch(ss[i].sid) { case 1:s[0][2]+=ss[i].sn;break;

10、 case 2:s[1][2]+=ss[i].sn;break; case 3:s[2][2]+=ss[i].sn;break; case 4:s[3][2]+=ss[i].sn;break; } break; case 4: switch(ss[i].sid) { case 1:s[0][3]+=ss[i].sn;break; case 2:s[1][3]+=ss[i].sn;break; case 3:s[2][3]+=ss

11、[i].sn;break; case 4:s[3][3]+=ss[i].sn;break; } break; case 5: switch(ss[i].sid) { case 1:s[0][4]+=ss[i].sn;break; case 2:s[1][4]+=ss[i].sn;break; case 3:s[2][4]+=ss[i].sn;break; case 4:s[3][4]+=ss[i].sn;break; };

12、 break; } } } 3.3.4-3【主菜单函数】menu() 显示系统功效菜单以供用户选择相关功效使用,依据用户选择分别可调用 detail():计算上个月每个人每种产品销售额 seller():按销售额对销售员进行排序,输出排序结果(销售员代号) product():统计每种产品总销售额,对这些产品按从高到低次序输出排序结果(需输出产品代号和销售额) exit(0):退出系统 void menu() { int w,c; do{ puts("\t\t*********菜单*********************\n\n");

13、 puts("\t\t 1.查看每人每种产品销售额\n"); puts("\t\t 2.按销售额对销售员排序(销售员代号)\n"); puts("\t\t 3.对每种产品总销售额从高到低排序(产品代号和销售额)\n"); puts("\t\t 4.输出统计报表\n"); puts("\t\t 5.退出\n"); puts("\n\n\t\t*********************************************\n"); printf("请选择(1-5):[

14、]\b\b"); scanf("%d",&c); if(c<1||c>5) //错误输入则重新获取输入 { 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

15、 5: exit(0); } } 3.3.5【功效函数】 5-1【每人每种产品销售额统计函数】detail() 计算上个月每个人每种产品销售额 void detail() //显示销售情况 { int i,j; for(i=0;i<4;i++) //遍历销售员 { printf("\n\t\t%d号销售员销售情况:\n",i+1); for(j=0;j<5;j++)

16、 //按销售员分类遍历全部产品并显示信息 printf("\t\t%d号产品销售数量:%d\n",j+1,s[i][j]); } choice(); } 3.3.5-1【销售员销售业绩排序函数】seller() 按销售额对销售员进行排序,输出排序结果(销售员代号) void seller() { int i,j,k; int sp[4]={0,0,0,0}; for(i=0;i<4;i++) for(j=0;j<5;j++) sp[i]+=s[i][j];

17、 //计算每单个销售员全部产品销售数量 for(i=0;i<4;i++) //比较四次,每次选出最大数 { k=0; //用于标识单轮最大数 for(j=0;j<4;j++) if(sp[k]

18、duct() 统计每种产品总销售额,对这些产品按从高到低次序输出排序 void product() //和seller()原理一样,用于对产品进行统计 { int i,j,k; int p[5]={0,0,0,0,0}; for(j=0;j<5;j++) for(i=0;i<4;i++) p[j]+=s[i][j]; for(j=0;j<5;j++) { k=0; for(i=0;i<5;i++) if(p[k]

19、\t销量为%d!\n",j+1,k+1,p[k]);p[k]=-1; } choice(); } 3.3.5-3【统计报表输出函数】total() 统计每种产品总销售额,对这些产品按从高到低次序输出排序结果(需输出产品代号和销售额) void total() //输出报表 { int i,j; printf("\n\t销售员\t产品\t销量\n"); for(i=0;i<4;i++) for(j=0;j<5;j++) printf("\t %d\t %d\t %d\n",i+1,j+1,s[i][j]); choice(); }

20、 3.3.6【公共函数】 【选择函数】choice() 选择退出系统或则返回主菜单 void choice() //用于输出信息功效选择 { int c; printf("请选择接下来想做什么\t1>返回菜单\t2>退出系统 [ ]\b\b"); scanf("%d",&c); if(c==1) menu(); else exit(0); puts('\n'); } 4、运行结果(附带抓图) List.txt(便条)文件中数据以下:(提前建立文件或就将便条保留在文件中!!!!! ) 1 1 1 1 2 2 1 3 3 1 4 8 1 5

21、 9 2 1 3 2 2 3 2 3 4 2 4 5 2 5 6 3 1 1 3 2 1 (这是个例子) 3 3 4 3 4 5 3 5 6 4 1 2 4 2 3 4 3 4 4 4 5 4 5 6 运行结果 显示主菜单: 查看每人每种产品销售额运行结果: 按销售额对销售员按次序排序(销售员代号)运行结果 对每种产品销售额从高到低排序运行结果:

22、 统计报表运行结果: 6、源程序 #include #include #include /*调用exit函数*/ #include #define M 155 /*宏定义*/ void detail(); void foreach(); void menu(); void product(); void readdata(); void seller(); void total(); void choice(); struct ss { int sid;

23、 //销售员代号 int pid; //产品代号 int sn; //销售额 }ss[M]; int n; //纸条数目 int s[4][5]={{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(); //显示主菜单 } void read

24、data() //从文件读取数据 { FILE *fp; if((fp=fopen("list.txt","r"))==NULL) { printf("Can't open the file!\n"); exit(0); } else for(n=0;!feof(fp);n++) { fscanf(fp,"%d %d %d\n",&ss[n].sid,&ss[n].pid,&ss[n].sn); } //保留文件数据到结构体 fclose(fp); } void foreach()

25、 //从纸条读取数据并分类整理 { int i; for(i=0;i

26、][0]+=ss[i].sn;break; case 4:s[3][0]+=ss[i].sn;break; } break; case 2: switch(ss[i].sid) { case 1:s[0][1]+=ss[i].sn;break; case 2:s[1][1]+=ss[i].sn;break; case 3:s[2][1]+=ss[i].sn;break; case 4:s[3][1]+=ss[i].sn;break;

27、 } break; case 3: switch(ss[i].sid) { case 1:s[0][2]+=ss[i].sn;break; case 2:s[1][2]+=ss[i].sn;break; case 3:s[2][2]+=ss[i].sn;break; case 4:s[3][2]+=ss[i].sn;break; } break; case 4: switch(ss[i].sid) {

28、case 1:s[0][3]+=ss[i].sn;break; case 2:s[1][3]+=ss[i].sn;break; case 3:s[2][3]+=ss[i].sn;break; case 4:s[3][3]+=ss[i].sn;break; } break; case 5: switch(ss[i].sid) { case 1:s[0][4]+=ss[i].sn;break; case 2:s[1][4]+=ss[i].sn;bre

29、ak; case 3:s[2][4]+=ss[i].sn;break; case 4:s[3][4]+=ss[i].sn;break; }; break; } } } void menu() { int w,c; do{ puts("\t\t********************菜单*********************\n\n"); puts("\t\t 1.查看每人每种产品销售额\n"); puts("\t\t 2.按销售额对销售员排

30、序(销售员代号)\n"); puts("\t\t 3.对每种产品总销售额从高到低排序(产品代号和销售额)\n"); puts("\t\t 4.输出统计报表\n"); puts("\t\t 5.退出\n"); puts("\n\n\t\t*********************************************\n"); printf("请选择(1-5):[ ]\b\b"); scanf("%d",&c); if(c<1||c>5) //错误输入则重新获取输入

31、 { 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()

32、 //显示销售情况 { int i,j; for(i=0;i<4;i++) //遍历销售员 { printf("\n\t\t%d号销售员销售情况:\n",i+1); for(j=0;j<5;j++) //按销售员分类遍历全部产品并显示信息 printf("\t\t%d号产品销售数量:%d\n",j+1,s[i][j]); } choice(); } void seller

33、) { int i,j,k; int sp[4]={0,0,0,0}; for(i=0;i<4;i++) for(j=0;j<5;j++) sp[i]+=s[i][j]; //计算每单个销售员全部产品销售数量 for(i=0;i<4;i++) //比较四次,每次选出最大数 { k=0; //用于标识单轮最大数 for(j=0;j<4;j++) if(sp[k]

34、 printf("\t\t第%d名是%d号销售员!\n",i+1,k+1);sp[k]=-1; //输出最大数和排名,将最大数标识为负 } choice();} void product() //和seller()原理一样,用于对产品进行统计 { int i,j,k; int p[5]={0,0,0,0,0}; for(j=0;j<5;j++) for(i=0;i<4;i++) p[j]+=s[i][j]; for(j=0;j<5;j++) {k=0; for(i=0;i<5;i++)

35、 if(p[k]返回菜单\t2>退出系统 [ ]\b\b"); scanf("%d",&c); if(c==1) menu(); else exit(0); puts('\n'); }

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

关于我们      便捷服务       自信AI       AI导航        抽奖活动

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

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

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

关注我们 :微信公众号    抖音    微博    LOFTER 

客服