搜索
您的当前位置:首页正文

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

2023-10-03 来源:易榕旅网
中国地质大学(武汉)C语言程序设计

报告正文

1、题目与要求:

1.1

某公司有四个销售员(编号:1-4),负责销售五种产品(编号:1-5)。每个销售员都将当日出售的每种产品各写一张便条交上来。每张便条内容有 1、销售员的代号 2、产品的代号

3、这种产品当天的销售额

1.2

每位销售员每天可能上缴0-5张便条。假设手机到了上个月的所有便条,编写一个处理系统,读取上月的销售情况(自己设定),进行如下处理: 1、计算上个月没人每种产品的销售额

2、按销售额对销售员进行排序,输出排序结果(销售员代号)

3、统计每种产品的总销售额,对这些产品从高到低的顺序输出结果(须输

出产品的代号和销售额) 4、输出统计报表

2、需求分析

本程序将用到文件系统,list.txt文件内容作为数据源,其中单行内容代表一

张纸条。程序运行后首先将文件系统的原始数据读取并保存到程序的结构体数组当中,所以应提供文件输入的操作;由于纸条数据零散,所以要对原始数据进行分类操作并提供一个数组用于保存分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功能选择。

1

中国地质大学(武汉)C语言程序设计

3、功能实现设计

3.1总体设计

根据上面的分析,可以将这个系统分为如下五大模块:查看每人每种产品的销售额 、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出。其中主要模块是前四个模块。

3.2流程图

2

中国地质大学(武汉)C语言程序设计

3.3详细设计:

3.3.1【头文件和预定义】 #include #include #include #include #define M 155

3.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 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;

3

中国地质大学(武汉)C语言程序设计

if((fp=fopen(\"list.txt\ {

printf(\"Can't open the file!\\n\"); exit(0); }

else

for(n=0;!feof(fp);n++) {

fscanf(fp,\"%d %d %d\\n\ } //保存文件数据到结构体 fclose(fp); }

3.3.4-2【文件读取函数】foreach()

将保存到结构体中的信息按产品分类,再根据销售员进行分类,将信息存到数组当中。

void foreach() //从纸条读取数据并分类整理 {

int i;

for(i=0;iswitch(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:

4

中国地质大学(武汉)C语言程序设计

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(\"\\*********菜单*********************\\n\\n\"); puts(\"\\ 1.查看每人每种产品的销售额\\n\");

puts(\"\\ 2.按销售额对销售员排序(销售员代号)\\n\");

puts(\"\\ 3.对每种产品总销售额从高到低排序(产品代号和销售

5

中国地质大学(武汉)C语言程序设计

额)\\n\");

puts(\"\\ 4.输出统计报表\\n\"); puts(\"\\ 5.退出\\n\");

puts(\"\\n\\n\\*********************************************\\n\"); printf(\"请选择(1-5):[ ]\\b\\b\"); scanf(\"%d\

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); } }

3.3.5【功能函数】

5-1【每人每种产品销售额统计函数】detail() 计算上个月每个人每种产品的销售额

void detail() //显示销售情况 {

int i,j;

for(i=0;i<4;i++) //遍历销售员 {

printf(\"\\n\\%d号销售员销售情况:\\n\

for(j=0;j<5;j++)

//按销售员分类遍历所有产品并显示信息 printf(\"\\%d号产品销售数量:%d\\n\

6

中国地质大学(武汉)C语言程序设计

}

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]printf(\"\\第%d名是%d号销售员!\\n\ //输出最大数和排名,将最大数标记为负 }

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]printf(\"\\第%d名是%d号产品!\销量为%d!\\n\ }

choice(); }

7

中国地质大学(武汉)C语言程序设计

3.3.5-3【统计报表输出函数】total() 统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)

void total() //输出报表 { int i,j;

printf(\"\\n\销售员\产品\销量\\n\"); for(i=0;i<4;i++) for(j=0;j<5;j++)

printf(\"\ %d\ %d\ %d\\n\ choice(); }

3.3.6【公共函数】 【选择函数】choice()

选择退出系统或则返回主菜单

void choice() //用于输出信息功能选择 {

int c;

printf(\"请选择接下来想做什么\1>返回菜单\2>退出系统scanf(\"%d\if(c==1) menu(); else

exit(0); puts('\\n'); }

4、运行结果(附带抓图)

List.txt(便条)文件中数据如下:

1 1 10 2 5 20 3 4 40 4 2 60 1 3 20

8

[ ]\\b\\b\"); 中国地质大学(武汉)C语言程序设计

3 4 30

运行结果

显示主菜单:

查看每人每种产品的销售额运行结果:

9

中国地质大学(武汉)C语言程序设计

按销售额对销售员排序运行结果:

对每种产品销售额从高到低排序运行结果:

10

中国地质大学(武汉)C语言程序设计

统计报表运行结果:

5、总结 11

中国地质大学(武汉)C语言程序设计

通过这次C程序设计,我掌握了模块化设计方法,能够深入的理解结构化程序设计思想,熟练运用结构化程序设计方法,提高了运用C语言进行程序设计的能力。此外我还熟悉了,对于文件读写的操作。更重要的是对程序的调试有了显著的提高。我发现我对程序的设计越来越感兴趣了,我决定今后在这一方面下一番功夫,取得一些成绩。

6、源程序

#include #include #include #include #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\ { printf(\"Can't open the file!\\n\"); exit(0);

12

中国地质大学(武汉)C语言程序设计

} else for(n=0;!feof(fp);n++) { fscanf(fp,\"%d %d %d\\n\ } //保存文件数据到结构体 fclose(fp); }

void foreach() //从纸条读取数据并分类整理 { int i; for(i=0;i13

中国地质大学(武汉)C语言程序设计

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(\"\\********************菜单*********************\\n\\n\"); puts(\"\\ 1.查看每人每种产品的销售额\\n\");

puts(\"\\ 2.按销售额对销售员排序(销售员代号)\\n\");

puts(\"\\ 3.对每种产品总销售额从高到低排序(产品代号和销售额)\\n\"); puts(\"\\ 4.输出统计报表\\n\"); puts(\"\\ 5.退出\\n\");

puts(\"\\n\\n\\*********************************************\\n\"); printf(\"请选择(1-5):[ ]\\b\\b\"); scanf(\"%d\

if(c<1||c>5) //错误输入则重新获取输入 { w=1; getchar(); }

else w=0; } while(w==1);

14

中国地质大学(武汉)C语言程序设计

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\\%d号销售员销售情况:\\n\ for(j=0;j<5;j++) //按销售员分类遍历所有产品并显示信息 printf(\"\\%d号产品销售数量:%d\\n\ } 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]15

中国地质大学(武汉)C语言程序设计

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]void total() //输出报表 { int i,j; printf(\"\\n\销售员\产品\销量\\n\"); for(i=0;i<4;i++) for(j=0;j<5;j++) printf(\"\ %d\ %d\ %d\\n\ choice(); }

void choice() //用于输出信息功能选择 { int c;

printf(\"请选择接下来想做什么\1>返回菜单\2>退出系统 [ ]\\b\\b\"); scanf(\"%d\if(c==1) menu(); else exit(0); puts('\\n'); }

16

因篇幅问题不能全部显示,请点此查看更多更全内容

Top