C语言程序设计-销售管理系统(共28页).docx

上传人:飞****2 文档编号:14480688 上传时间:2022-05-04 格式:DOCX 页数:28 大小:94.23KB
返回 下载 相关 举报
C语言程序设计-销售管理系统(共28页).docx_第1页
第1页 / 共28页
C语言程序设计-销售管理系统(共28页).docx_第2页
第2页 / 共28页
点击查看更多>>
资源描述

《C语言程序设计-销售管理系统(共28页).docx》由会员分享,可在线阅读,更多相关《C语言程序设计-销售管理系统(共28页).docx(28页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上 计算机高级语言课程设计(C) 实习报告 姓名: 刘晓东 题目: 销售管理系统 班级: 软件 三班 学号: 学院: 专业: 指导老师: 陈作汉 201312.20 目录一 题目与要求 - - - - - - - - - - - - - - - 3二 需求分析 - - - - - - - - - - - - - - - - 3三 功能实现设计(模块化设计)- - - 3 四 运行结果(附带抓图)- - - - - - - -9五 总结 - - - - - - - - - - - - - - - - - - - 13六 源程序 - - - - - - - - - - -

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

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

4、上的信息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用于保存原始数据。

5、然后定义全局变量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-1【文

6、件读取函数】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()将保存到结构体中的信息按产品分类,再根据销售员进行分类,将信息存到数组当中。

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

8、; 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; cas

9、e 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():按销售额对销售员进行排序,输出排序结果(销

10、售员代号)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) /

11、错误输入则重新获取输入 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+) /遍历销售员prin

12、tf(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; /用于标记单轮最大数for(j=0

13、;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=0;i5;i+)if(pkp

14、i)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.txt(便条)文件中数据如下:(提前建立

15、文件或就将便条保存在文件中! )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运行结果 显示主菜单: 查看每人每种产品的销售额运行结果:按销售额对销售员按顺序排序(销售员代号)运行结果对每种产品销售额从高到低排序运行结果:统计报表运行结果:5、总结 通过这次C程序设计,我掌握了模块化设计方法(例如函数模块),能够深入的理解结构化程序设计思想,熟练运用结构化程序设计方法,提高了运用C语言进行程序设计的能力。虽然刚开始我对文件的读

16、写感到很茫然,但是通过查找网上资料和翻阅有关书籍,我逐渐领悟了文件读写的核心思想。因此,对于文件读写的操作。更重要的是对程序的调试有了显著的提高。我发现我对程序的设计越来越感兴趣了,我决定今后在这一方面下一番功夫,取得一些成绩。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();s

17、truct 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)=NULL)printf(Cant open th

18、e 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+=ssi.sn;break; case 3

19、: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.sn;break; case 4:s32

20、+=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;break; ; break; void m

21、enu()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(c) /根据输入实现相应函数调用 case

22、 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();void seller()int i,

23、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号产品!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);专心-专注-专业

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁