#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <stdlib.h>
#include <windows.h>
#define Z 5
#define R 4                   /*定义宏常量便于程序的一般化*/ /*R表示销售员个数*/
typedef struct                 /*缩短结构体变量名*/
{  int shangpin[Z];          /*定义结构体便于信息的存储和读写,辨别*/
}data;				/*R是表示商品的种类,最后一个为该销售员商品总和*/




void menu()
{	system("cls");						/*清屏命令*/
	printf("\n\n");
	printf("\t┏━━━━━━主菜单━━━━━━┓\n");
	printf("\t┃        1.录入当天销售情况        ┃\n");
	printf("\t┃        2.查询                    ┃\n");
	printf("\t┃        3.修改                    ┃\n");
	printf("\t┃        4.输出统计报表            ┃\n");
	printf("\t┃        5.结束操作                ┃\n");
printf("\t┗━━━━━━━━━━━━━━━┛\n");
}


void menu2()
{	system("cls");						/*清屏命令*/
	printf("\n\n");
	printf("\t ┏━━━━━━━━━━━━子菜单━━━━━━━━━━┓\n");
	printf("\t ┃        1.计算上个月每个人每种产品的销售额        ┃\n");
	printf("\t ┃        2.按销售额对销售员进行排序,输出排序结果  ┃\n");
	printf("\t ┃        3.统计每种产品的总销售额,输出排序结果     ┃\n");
	printf("\t ┃        4.查询当天输入情况                        ┃\n");
	printf("\t ┃        5.结束操作                                ┃\n");
printf("\t ┗━━━━━━━━━━━━━━━━━━━━━━━━━┛\n");



void f1(data *x)              /*计算上个月每个人每种产品的销售额*/
{	FILE *fp;
	char fname[10],hitkey;
	int j,t;                              /*用于控制循环*/
	int i,k,s;                    /*用于定义职工序号,产品序号,产品数量*/
	system("cls");					/*清屏命令*/
	printf("您想计算哪个月?\n");
	printf("请输入月份:");     /*输入文件名,这样可以进行各个月份信息写入*/
	scanf("%s",fname);
	strcat(fname,".dat");
	if((fp=fopen(fname,"wb"))==NULL)          /*打开文件*/
	{	printf("不能打开文件!!!\n");
		exit(0);							/* 正常exit(0);结束程序*/
	}
	for(j=0;j<R;j++)                      /*对商品数量清零*/
		for(t=0;t<Z;t++)
			(x+j)->shangpin[t]=0;
	printf("请输入:\n职工编号	产品编号	销售数量\n");          /*提示用户写入信息的格式*/
	for(j=0;hitkey!=27;j++)
	{	scanf("%d%d%d",&i,&k,&s);
		if(i>R||i<0||k>Z||k<0)
		{	printf("信息错误!\n");   /*提示语,避免输入信息出错*/
			continue;
		}
		else
			(x+i-1)->shangpin[k-1]=(x+i-1)->shangpin[k-1]+s;          /*统计各个人的各种产品的数量,-1为了和数组中的序号相匹配*/
		printf("继续输入请按回车,结束输入请按esc\n");
		printf("━━━━━━━━━━━━━━━━━━━━━━\n");
		hitkey=getch();
		for (;hitkey!=13&&hitkey!=27;)
		hitkey=getch();
	}
	for(j=0;j<R;j++)
		if(fwrite((x+j),sizeof(data),1,fp)!=1)          /*把信息写入文件中便有以后调用*/
			printf("write error!\n");
	fclose(fp);                             /*关闭文件避免信息遗漏*/
	printf("\n\n\n\n\n\n\t\t\t保存成功,按任意键返回主菜单!");
    getch();
}



void f2(data *x)         /*按销售额对销售员进行排序,输出排序结果*/
{	FILE *fp;
	char fname[10];
	int i,k,j,t,bianhao[R]={0},z;
	system("cls");						/*清屏命令*/
	printf("你要哪个月的?\n");
	printf("请输入月份:");        /*输入文件名,这样可以进行各个月份信息读入*/
	scanf("%s",fname);
	strcat(fname,".dat");
	if((fp=fopen(fname,"rb"))==NULL)           /*打开文件*/
	{	printf("不能打开文件!!!\n");
		exit(0);
	}
	for(i=0;i<R;i++)                          /*读出信息*/
		if(fread(x+i,sizeof(data),1,fp)!=1)
			printf("读入信息出错!");         /*读入信息提示*/
	for(i=0;i<R;i++)                         /*用于存储职工编号*/
		bianhao[i]=i;
	printf("请输入按何种产品排序\n");
	scanf("%d",&k);
	k=k-1;                           /*便于与结构体中的数组值对应*/
	for(i=0;i<R;i++)               /*按K种产品对销售员排序,选择法排序*/
	{	t=i;
		for(j=i+1;j<R;j++)
			if((x+bianhao[t])->shangpin[k]<(x+bianhao[j])->shangpin[k])/*调用职工各自对应的结构体内的产品数量*/  t=j;
		if(t!=i)
		{	z=bianhao[i];
			bianhao[i]=bianhao[t];
			bianhao[t]=z;
		}
	}
	printf("\t\t\t按%d产品对销售员排序为:\n",k+1);
	printf("━━━━━━━━━━━━━━━━━━━━━\n");
	for(i=0;i<R;i++)
		printf("\t\t\t第%d名是: 员工%d\n",i+1,bianhao[i]+1);
	printf("\n\n\n\t\t\t按任意键返回上一主菜单!");
	getch();
	fclose(fp);		/*关闭读入的文件*/
}



void f3(data *x)     	/*统计每种产品的总销售额,输出排序结果*/
{	FILE *fp;
	char fname[10];
	int i,j,sum[Z]={0},bianhao[Z]={0},z,t,k;
    system("cls");								/*清屏命令*/
	printf("您想计算哪个月的?\n");
	printf("请输入月份:");    		/*输入文件名,这样可以进行各个月份信息读入*/
	scanf("%s",fname);
	strcat(fname,".dat");
	if((fp=fopen(fname,"rb"))==NULL)             /*打开文件*/
	{	printf("不能打开文件!!!\n");
		exit(0);
	}
	for(i=0;i<R;i++)                        /*读出信息*/
		if(fread(x+i,sizeof(data),1,fp)!=1)
			printf("读入信息出错!");
	for(i=0;i<Z;i++)                      /*对各种商品求和*/
		for(j=0;j<R;j++)
			sum[i]=sum[i]+(x+j)->shangpin[i];
	for(i=0;i<Z;)                        /*用于存储商品编号*/
		bianhao[i]=i++;
	for(i=0;i<Z;i++)
		printf("%3d",bianhao[i]);
    for(i=0;i<Z;i++)              /*对产品从高到低排序,选择法排序*/
	{	t=i;
		for(j=i+1;j<Z;j++)    /*产品变化时,产品编号也随之变化,便于输出*/
			if(sum[t]<sum[j])
				t=j;
		if(t!=i)
		{	k=sum[i];
			sum[i]=sum[t];
			sum[t]=k;
			z=bianhao[i];
			bianhao[i]=bianhao[t];
			bianhao[t]=z;
		}
	}
	printf("输出产品排序\n");
	printf("产品编号  数量\n");
	printf("━━━━━━━━━━━━━\n");
	for(i=0;i<Z;i++)
	printf(" 产品%-7d%-1d\n",bianhao[i]+1,sum[i]);
	printf("\n\n\n\t\t\t按任意键返回主菜单!");
	getch();
	fclose(fp);					/*关闭读入的文件*/
}



void f4(data *x)                 /*输出统计报表*/
{	FILE *fp;
	char fname[10];
    int i,j,sum[Z+1]={0};
    system("cls");								/*清屏命令*/
	printf("您想计算哪个月?\n");
	printf("请输入月份:");              /*实为输入一个文件名,这样可以进行各个月份的信息读入*/
	scanf("%s",fname);
	strcat(fname,".dat");
	if((fp=fopen(fname,"rb"))==NULL)               /*打开文件*/
	{   printf("不能打开文件!!!\n");
		exit(0);
	}
    for(i=0;i<R;i++)                            /*读出信息*/
		if(fread(x+i,sizeof(data),1,fp)!=1)
			printf("读入信息出错!");
    for(i=0;i<Z;i++)                                /*对各种商品求和*/
		for(j=0;j<R;j++)
			sum[i]=sum[i]+(x+j)->shangpin[i];
    for(i=0;i<Z;i++)                               /*求商品总和*/
		sum[Z]=sum[Z]+sum[i];
	printf("━━━━━━━━━━━━━━━━━━━━━━━━━━━\n");
	printf("输出统计报表如下:\n");                 /*按要求输出统计表*/
	printf("销售员代号  产品代号  销售之和\n");
	for(i=0;i<R;i++)
		for(j=0;j<Z;j++)
			printf(" 员工%-8d产品%-6d数量%-10d\n",i+1,j+1,(x+i)->shangpin[j]);
	printf("━━━━━━━━━━━━━━━━━━━━━━━━━━━\n");
	for(i=0;i<Z;i++)
	{	if(i==0)
			printf("产品%d之和   %-10d   总和  %-10d\n",i+1,sum[i],sum[Z]);
		else
			printf("产品%d之和   %-10d\n",i+1,sum[i]);
	}
	printf("\n\n\n\t\t\t按任意键返回主菜单!");
	getch();
}

void f5(data *x)
{
    FILE *fp;
    char fname[10],hitkey;
	int j,t;                              /*用于控制循环*/
	int i,k,s;                    /*用于定义职工序号,产品序号,产品数量*/
	system("cls");
	strcat(fname,".dat");
	if((fp=fopen(fname,"wb"))==NULL)          /*打开文件*/
	{	printf("不能打开文件!!!\n");
		exit(0);							/* 正常exit(0);结束程序*/
	}					/*清屏命令*/
 for(j=0;j<R;j++)    /*对商品数量清零*/
		for(t=0;t<Z;t++)
 (x+j)->shangpin[t]=0;
 printf("请输入:\n职工编号	产品编号	销售数量\n");          /*提示用户写入信息的格式*/
 for(j=0;hitkey!=27;j++)
 {	scanf("%d%d%d",&i,&k,&s);
 if(i>R||i<0||k>Z||k<0)
 {	printf("信息错误!\n");   /*提示语,避免输入信息出错*/
 continue;
 }
		else
			(x+i-1)->shangpin[k-1]=(x+i-1)->shangpin[k-1]+s;          /*统计各个人的各种产品的数量,-1为了和数组中的序号相匹配*/
		printf("继续输入请按回车,结束输入请按esc\n");
		printf("━━━━━━━━━━━━━━━━━━━━━━\n");
		hitkey=getch();
		for (;hitkey!=13&&hitkey!=27;)
		hitkey=getch();
	}
	for(j=0;j<R;j++)
		if(fwrite((x+j),sizeof(data),1,fp)!=1)          /*把信息写入文件中便有以后调用*/
			printf("write error!\n");
	fclose(fp);                             /*关闭文件避免信息遗漏*/
	printf("\n\n\n\n\n\n\t\t\t保存成功,按任意键返回主菜单!");
    getch();
}
}


void main()
{	int i,choice,choice2;
	data sxy[R];         /*R表示职工的个数,前面的宏常量*/
printf("\n\n\n\n\n\n\t━━━━━━━━━━━━━━━━━━━━━━━━━\n");
	printf("\t---------------欢迎进入商品销售系统!-------------\n");
	printf("\t━━━━━━━━━━━━━━━━━━━━━━━━━\n");
	printf("\n\n\n\n\n\n\t\t\t按任意键进入主菜单!");
	getch();
	for(i=0;;i++)
	{	system("cls");                /*清屏命令*/
		menu();                        /*主菜单函数提示用户怎样选择*/
		printf("你想做什么?\n");
		printf("请选择:");            /*输入要进行的操作*/
		scanf("%d",&choice);
		if(choice==5)
		{		system("cls");						/*清屏命令*/
				printf("\n\n\n\n\n\n\t━━━━━━━━━━━━━━━━━━━━━━━━━\n\n");
				printf("\t---------------谢谢使用商品销售系统!-------------\n\n");
				printf("\t━━━━━━━━━━━━━━━━━━━━━━━━━\n\n");
				printf("\n\n\n\n\n\n\t\t\t按任意键退出!(^.^)");
				getch();
			break;                       /*退出整个程序*/
		}
		else
			switch(choice)
		   { 	case 1:f5(sxy);break;      /*计算上个月每个人每种产品的销售额*/
			    case 2: menu2();
 printf("你想做什么?\n");
 printf("请选择:"); /*输入要进行的操作*/
 scanf("%d",&choice2);
 if(choice2==5)
 { system("cls"); /*清屏命令*/
 printf("\n\n\n\n\n\n\t━━━━━━━━━━━━━━━━━━━━━━━━━\n\n");
 printf("\t---------------谢谢使用商品销售系统!-------------\n\n");
 printf("\t━━━━━━━━━━━━━━━━━━━━━━━━━\n\n");
 printf("\n\n\n\n\n\n\t\t\t按任意键退出!(^.^)");
 getch();
 break;                       /*退出整个程序*/
 }switch(choice2)
 {
 case 1:f1(sxy); break;
 case 2:f2(sxy); break;
 case 3:f3(sxy); break;


		                   };break;      /*按销售额对销售员的销售情况进行排序,并且输出排序的结果*/
			    case 3:f5(sxy);break;        /*统计每种产品的总共得销售额,并且输出排序的结果*/
			    case 4:f4(sxy);break;          /*输出统计报表*/
		}
	}
}