收藏 分销(赏)

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

上传人:w****g 文档编号:2993112 上传时间:2024-06-12 格式:DOCX 页数:30 大小:68.10KB 下载积分:12 金币
下载 相关 举报
C语言程序设计销售标准管理系统.docx_第1页
第1页 / 共30页
C语言程序设计销售标准管理系统.docx_第2页
第2页 / 共30页


点击查看更多>>
资源描述
销售信息管理系统设计文档 组号:第二组 组员:汪品高 齐瑞智 欧阳鑫 赵飞锋 章森 目录 一. 题目和要求 二. 功效实现设计(模块化设计) 三. 运行结果(附带抓图) 四. 源程序 汇报正文 1、 题目和要求: 2、 某企业有四个销售员(编号:1-4),负责销售五种产品(编号:1-5)。每个销售员汇总当日出售每种产品销售情况。 2 天天销售情况包含(销售员代号、产品代号、这种产品当日销售额) 1、 编写一个销售信息管理系统,读取上个月销售情况 1、 计算上个月没人每种产品销售额 2、 按销售额对销售员进行排序,输出排序结果(销售员代号) 3、 统计每种产品总销售额,对这些产品从高到低次序输出结果(须输出产品代号和销售额) 4、 输出统计报表 2、需求分析 本程序将用到文件系统E://54321.doc文件内容作为数据源,其中单行内容代表一张纸条。程序运行后首先将文件系统原始数据读取并保留到程序结构体数组当中,所以应提供文件输入操作;因为纸条数据零碎,所以要对原始数据进行分类操作并提供一个数组用于保留分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功效选择。 3、功效实现设计 3.1总体设计 依据上面分析,能够将这个系统分为以下五大模块:查看每人每种产品销售额 、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出。其中关键模块是前四个模块。 开始 3.2步骤图 推出系统 读取便条上信息 3.3具体设计: 3.3.1【头文件和预定义】 #include<stdio.h> #include<conio.h> 主菜单 #include<stdlib.h> #include<string.h> #define M 3.3.2【功效函数申明】 vvoid detail(); void foreach(); 输出统计表 统计总销售额并排序 销售员销售业绩排序 每个人每种产品销售额 void menu(); void product(); void readdata(); void seller(); void total(); 选择 void choice(); 退出系统 返回主菜单 3.3.3【数据结构】 原始数据有销售员代号、产品代号和销售额,所以定义一个全局结构体数组scrip用于保留原始数据。然后定义全局变量n保留纸条数目,定义数组s用于保留分类后信息。 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(); //依据文件初始数据初始化便于操作数组 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++) { 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<n;i++) //遍历全部纸条 { switch(ss[i].pid) //按产品分大类(比如就是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: 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; 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[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; }; break; } } } 3.3.4-3【主菜单函数】menu() 显示系统功效菜单以供用户选择相关功效使用,依据用户选择分别可调用 detail():计算上个月每个人每种产品销售额 seller():按销售额对销售员进行排序,输出排序结果(销售员代号) product():统计每种产品总销售额,对这些产品按从高到低次序输出排序结果(需输出产品代号和销售额) exit(0):退出系统 void menu() { int w,c; do{ puts("\t\t*********菜单*********************\n\n"); 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):[ ]\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 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++) //按销售员分类遍历全部产品并显示信息 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]; //计算每单个销售员全部产品销售数量 for(i=0;i<4;i++) //比较四次,每次选出最大数 { k=0; //用于标识单轮最大数 for(j=0;j<4;j++) if(sp[k]<sp[j])k=j; //获取最大数标号 printf("\t\t第%d名是%d号销售员!\n",i+1,k+1);sp[k]=-1; //输出最大数和排名,将最大数标识为负 } choice(); } 3.3.5-2【总销售额统计函数】void product() 统计每种产品总销售额,对这些产品按从高到低次序输出排序 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]<p[i])k=i; printf("\t\t第%d名是%d号产品!\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(); } 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 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 运行结果 显示主菜单: 查看每人每种产品销售额运行结果: 按销售额对销售员按次序排序(销售员代号)运行结果 对每种产品销售额从高到低排序运行结果: 统计报表运行结果: 6、源程序 #include<stdio.h> #include<conio.h> #include<stdlib.h> /*调用exit函数*/ #include<string.h> #define M 155 /*宏定义*/ void detail(); void foreach(); void menu(); void product(); void readdata(); void seller(); void total(); void choice(); 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}}; //用于保留职员和产品信息 void main() //入口函数,即主函数 { p readdata(); //读取文件数据 foreach(); //依据文件初始数据初始化便于操作数组 menu(); //显示主菜单 } 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++) { fscanf(fp,"%d %d %d\n",&ss[n].sid,&ss[n].pid,&ss[n].sn); } //保留文件数据到结构体 fclose(fp); } void foreach() //从纸条读取数据并分类整理 { int i; for(i=0;i<n;i++) //遍历全部纸条 { switch(ss[i].pid) //按产品分大类,依据大类分销售员小类,累加个人各产品销售数量 { 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: 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; 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[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; }; break; } } } void menu() { int w,c; do{ puts("\t\t********************菜单*********************\n\n"); 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):[ ]\b\b"); scanf("%d",&c); if(c<1||c>5) //错误输入则重新获取输入 { 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;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() { 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]<sp[j])k=j; //获取最大数标号 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++) if(p[k]<p[i])k=i; printf("\t\t第%d名是%d号产品!\t销量为%d!\n",j+1,k+1,p[k]);p[k]=-1;} choice(); } 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(); } void choice() //用于输出信息功效选择 { int c; printf("请选择接下来想做什么\t1>返回菜单\t2>退出系统 [ ]\b\b"); scanf("%d",&c); if(c==1) menu(); else exit(0); puts('\n'); }
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 通信科技 > 开发语言

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

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

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

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

gongan.png浙公网安备33021202000488号   

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

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

客服