C语言程序设计_销售管理系统.pdf
1 销售信息管理系统设计文档组号:第二组成员:汪品高齐瑞智 欧阳鑫 赵飞锋 章森目录一题目与要求二功能实现设计(模块化设计)2 三运行结果(附带抓图)四源程序报告正文1、题目与要求:2、某公司有四个销售员(编号:1-4),负责销售五种产品(编号:1-5)。每个销售员汇总当天出售的每种产品的销售情况。2 每天销售情况包括(销售员的代号、产品的代号、这种产品当天的销售额)1、编写一个销售信息管理系统,读取上个月的销售情况1、计算上个月没人每种产品的销售额3 2、按销售额对销售员进行排序,输出排序结果(销售员代号)3、统计每种产品的总销售额,对这些产品从高到低的顺序输出结果(须输出产品的代号和销售额)4、输出统计报表2、需求分析本程序将用到文件系统,其中单行内容代表一张纸条。程序运行后首先将文件系统的原始数据读取并保存到程序的结构体数组当中,所以应提供 文件输入的操作;由于纸条数据零散,所以要对原始数据 进行分类操作并提供一个数组用于保存分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供 键盘式选择菜单 实现功能选择。3、功能实现设计总体设计根据上面的分析,可以将这个系统分为如下五大模块:查看每人每种产品的销售额、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出。其中主要模块是前四个模块。流程图详细设计:开推出系统读 取 便 条上的信息4【头文件和预定义】#include#include#include#include#define M【功能函数声明】vvoid detail();void foreach();void menu();void product();void readdata();void seller();void total();void choice();【数据结构】原始数据有销售员代号、产品代号和销售额,所以定义一个 全局结构体数组scrip 用于保存原始数据。然后定义全局变量n保存纸条数目,定义数组 s用于保存分类后的信息。struct ss主菜单每 个 人每 种 产 品 销销售员销售业绩排序统 计 总 销售额并排序输出统计表选择退出系统返回主菜单5 int sid;id,&ssn.pid,&ssn.sn);id)id)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:s02+=ssi.sn;break;case 2:s12+=ssi.sn;break;case 3:s22+=ssi.sn;break;6 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;break;break;【主菜单函数】menu()显示系统功能菜单以供用户选择相关功能使用,根据用户选择分别可调用7 detail():计算上个月每个人每种产品的销售额seller():按销售额对销售员进行排序,输出排序结果(销售员代号)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)8 9 id,&ssn.pid,&ssn.sn);id)id)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;10 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:s23+=ssi.sn;break;case 4:s33+=ssi.sn;break;break;case 5:switch(ssi.sid)11 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()i nt 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;12 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()/显示销售情况i nt i,j;for(i=0;i4;i+)/遍历销售员13 printf(ntt%d号销售员销售情况:n,i+1);for(j=0;j5;j+)/按销售员分类遍历所有产品并显示信息 printf(tt%d号产品销售数量:%dn,j+1,sij);choice();void seller()i nt i,j,k;i nt sp4=0,0,0,0;f or(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()原理一样,用于对产品进行统计14 int i,j,k;i nt p5=0,0,0,0,0;f or(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);f or(i=0;i4;i+)for(j=0;j 返回菜单 t2 退出系统 bb);15 scanf(%d,&c);if(c=1)menu();elseexit(0);puts(n);