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

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-5334762.html】到电脑端继续下载(重复下载不扣费)。

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

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(C语言课程设计销售管理系统报告.doc)为本站会员(wj)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

C语言课程设计销售管理系统报告.doc

1、报告正文1、题目与要求:1.1某公司有四个销售员(编号:1-4),负责销售五种产品(编号:1-5)。每个销售员都将当日出售的每种产品各写一张便条交上来。每张便条内容有 销售员的代号 产品的代号 这种产品当天的销售额1.2每位销售员每天可能上缴0-5张便条。假设手机到了上个月的所有便条,编写一个处理系统,读取上月的销售情况(自己设定),进行如下处理: 计算上个月没人每种产品的销售额 按销售额对销售员进行排序,输出排序结果(销售员代号) 统计每种产品的总销售额,对这些产品从高到低的顺序输出结果(须输出产品的代号和销售额) 输出统计报表2、需求分析 本程序将用到文件系统,list.txt文件内容作为

2、数据源,其中单行内容代表一张纸条。程序运行后首先将文件系统的原始数据读取并保存到程序的结构体数组当中,所以应提供文件输入的操作;由于纸条数据零散,所以要对原始数据进行分类操作并提供一个数组用于保存分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功能选择。3、功能实现设计3.1总体设计根据上面的分析,可以将这个系统分为如下五大模块:查看每人每种产品的销售额 、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出。其中主要模块是前四个模块。3.2流程图3.3详细设计: 3.3.1【头文件和预定义】#include#include#inc

3、lude#include#define M 1553.3.2【功能函数声明】void detail();void foreach();void menu();void product();void readdata();void seller();void total();void choice();3.3.3【数据结构】原始数据有销售员代号、产品代号和销售额,所以定义一个全局结构体数组scrip用于保存原始数据。然后定义全局变量n保存纸条数目,定义数组s用于保存分类后的信息。struct ssint sid; /销售员代号int pid; /产品代号int sn; /销售额 ssM; int

4、 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-1【文件读取函数】readdata()读出便条中的内容,并保存到文件结构体中void readdata() /从文件读取数据FILE *fp;if(fp=fopen(list.txt,r)

5、=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()将保存到结构体中的信息按产品分类,再根据销售员进行分类,将信息存到数组当中。 void foreach() /从纸条读取数据并分类整理int i;for(i=0;in;i+) /遍历所有纸条switch(ssi.pid) /按产品分大类,根据大类分销售员小类,累加个人各产品

6、销售数量 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;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) c

7、ase 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; 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

8、:s14+=ssi.sn;break; case 3:s24+=ssi.sn;break; case 4:s34+=ssi.sn;break; ; break; 3.3.4-3【主菜单函数】menu()显示系统功能菜单以供用户选择相关功能使用,根据用户选择分别可调用detail():计算上个月每个人每种产品的销售额seller():按销售额对销售员进行排序,输出排序结果(销售员代号)product():统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)exit(0):退出系统 void menu()int w,c;do puts(tt*菜单*nn); pu

9、ts(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) /错误输入则重新获取输入 w=1; getchar(); else w=0; while(w=1); switch(c) /根据输入实现相应函数调用 case 1: detail();break;/每个销售员每种产品的销售额统

10、计 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(ntt%d号销售员销售情况:n,i+1); for(j=0;j5;j+) /按销售员分类遍历所有产品并显示信息 printf(tt%d号产品销售数量:%dn,j+1,sij); choice()

11、;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;j+)if(spkspj)k=j; /获取最大数标号printf(tt第%d名是%d号销售员!n,i+1,k+1);spk=-1; /输出最大数和排名,将最大数标记为负choice();3.3

12、.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;printf(tt第%d名是%d号产品!t销量为%d!n,j+1,k+1,pk);pk=-1;choice();3.3.5-3【统计报表输出函数】total()统计每种产品的总销售额,对这些

13、产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)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(便条)文件中数据如下:1 1 102 5 20 3 4 404 2 60 1 3 203 4 30运行结果显示主菜单:查看每人每种产品的销售额运行结果:按销售额对销售员排序运行结果:对每种产品销售额从高到低排序运行结果:统计报表运行结

14、果:5、总结 通过这次C程序设计,我掌握了模块化设计方法,能够深入的理解结构化程序设计思想,熟练运用结构化程序设计方法,提高了运用C语言进行程序设计的能力。此外我还熟悉了,对于文件读写的操作。更重要的是对程序的调试有了显著的提高。我发现我对程序的设计越来越感兴趣了,我决定今后在这一方面下一番功夫,取得一些成绩。6、源程序#include#include#include#include#define M 155void detail();void foreach();void menu();void product();void readdata();void seller();void tot

15、al();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(); /显示主菜单void readdata() /从文件读取数据FILE *fp;if(fp=fopen(list.txt,r)!=NUL

16、L)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) /按产品分大类,根据大类分销售员小类,累加个人各产品销售数量 case 1: switch(ssi.sid) case 1:s00+=ssi.sn;break; case 2:s10+

17、=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:s02+=ssi.sn;break; case 2:s12+=ssi.sn;break; case 3:s22+=ssi

18、.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+=ssi.sn;break; case 3:s24+=ssi.sn;break; case 4:s34+=ssi.sn;b

19、reak; ; 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) /错误输入则重新获取输入 w=1; getchar(); else w=0; while(w=1); switch(

20、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+) /按销售员分类遍历所有产品并显示信息 printf(tt%d号产品销售数量:%dn,j+1,sij); choice(

21、);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(); 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号产品

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2