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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

C语言程序设计销售管理系统word文档良心出品.docx

1、C语言程序设计销售管理系统word文档良心出品 销售信息管理系统设计文档 组号:第二组 成员:汪品高 齐瑞智 欧阳鑫 赵飞锋 章森 一 题目与要求二 功能实现设计(模块化设计)三 运行结果(附带抓图)四 源程序 报告正文1、题目与要求:2、某公司有四个销售员(编号:1-4),负责销售五种产品(编号:1-5)。每个销售员汇总当天出售的每种产品的销售情况。2 每天销售情况包括(销售员的代号、产品的代号、这种产品当天的销售额)1、 编写一个销售信息管理系统,读取上个月的销售情况1、 计算上个月没人每种产品的销售额2、 按销售额对销售员进行排序,输出排序结果(销售员代号)3、 统计每种产品的总销售额,

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

3、序、输出统计报表和退出。其中主要模块是前四个模块。3.2流程图 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用于保存原始数据。然后定义全局变量n保存纸条数目,定义数

4、组s用于保存分类后的信息。struct ss int 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-1【文件读取函数】readdata()

5、读出便条中的内容,并保存到文件结构体中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()将保存到结构体中的信息按产品分类,再根据销售员进行分类,将信息存到数组当中。 void for

6、each() /从纸条读取数据并分类整理 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;break; case

7、 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; case 3:s

8、23+=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+) /遍历销售员 print

11、f(ntt%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; /用于标记单轮最大数 f

12、or(j=0;j4;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

13、=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()统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)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

14、.txt(便条)文件中数据如下:(提前建立文件或就将便条保存在文件中! )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 /*宏定义*/vo

15、id detail();void foreach();void menu();void product();void readdata();void seller();void total();void choice();struct ss int 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();

16、/根据文件初始数据初始化便于操作的数组 menu(); /显示主菜单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+) /遍历所有纸条 swit

17、ch(ssi.pid) /按产品分大类,根据大类分销售员小类,累加个人各产品销售数量 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;b

18、reak; 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; case 3:s23+=ssi.sn;break; case 4:s33+=ssi.sn;break; break; case 5: switch(ss

19、i.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; 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(nnt

20、t*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;/每个销售员每种产品的销售额统计 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+) /

21、遍历销售员 printf(ntt%d号销售员销售情况:n,i+1); for(j=0;j5;j+) /按销售员分类遍历所有产品并显示信息 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; /获取最大数标号 print

22、f(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号产品!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);

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

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