某销售公司在年末的时候会向员工发放红包,发放的红包金额共有5种,获取的条件各不相同: 1) 五颗星红包,每人8000元,平均月绩效大于80件商品(>80),并且在本年度满勤; 2) 四颗星红包,每人4000元,平均月绩效大于85件商品(>85),并且在民主评议中高于80分(>80)的员工均可获得; 3) 三颗星红包,每人2000元,平均月绩效大于90件商品(>90)的员工均可获得; 4) 二颗星红包,每人1000元,平均月绩效大于85件商品(>85)的外地员工均可获得; 5) 一颗星红包,每人850元,民主评议高于80分(>80)的优秀员工均可获得; 只要符合条件就可以获得年终红包,每个级别的红包没有获奖人数限制,每名员工可以同时获得多个级别的红包。 现在给出若干员工的相关数据,请计算哪位员工获得的红包金额最高。 输入: 第一行数据用于输入员工总数X(1 <= X <= 100),接下来的X行每行是一名员工的数据,从左向右依次是姓名,平均月绩效,民主评议成绩,是否是优秀员工,是否是外地员工,以及是否年度满勤。姓名是由大小写英文字母组成的长度不超过20的字符串(不含空格);平均月绩效和民主评议成绩都是0到100之间的整数(包括0和100);是否是优秀员工、是否是外地员工以及是否年度满勤均用布尔变量表示,Y表示是,N表示不是。每两个相邻数据项之间用一个空格分隔。 输出: 输出数据包括三行,第一行是获得红包金最多的员工姓名,第二行是这位员工获得的红包金额总数。如果有两名或两名以上的员工获得的奖金最多,输出他们之中在输入数据中出现最早的员工的姓名。第三行是这X名员工获得的红包金额的总数。 输入: 5 a 87 82 Y N N b 88 78 N Y Y c 92 88 N N N d 83 87 Y N Y e 90 88 Y N Y 输出: e 12850 41550
分析:本题题主定义了三个函数,实现的功能分别为读取数据、分析数据、打印数据。鉴于每个员工为一个单位,故采用结构体的方式进行数据输入,题中要求输出出现最早的员工的姓名,代码部分可体现为for循环的逆过程,废话不多说,代码如下:
#include<stdio.h>
#include<string.h>
#define MAX 100
typedef struct stu
{
char name[20];
int mon;
int score;
char yx;
char wd;
char mq;
int sum;
}Stu; //定义了含有七个基本数据类型变量的结构体;
void Readf(Stu emp[MAX],int n);//读取数据
void ana(Stu emp[MAX],int n); //分析数据
void prinf(Stu emp[MAX],int n);//打印数据
int main()
{
int n;
Stu emp[MAX];
scanf("%d",&n);
Readf(emp,n);
ana(emp,n);
prinf(emp,n);
return 0;
}
void Readf(Stu emp[MAX],int n)
{
int i;
for(i=0;i<n;i++)
{
emp[i].sum=0; //总金额初始化为0;
}
for(i=0;i<n;i++)
{
scanf("%s %d %d %c %c %c",emp[i].name,&emp[i].mon,&emp[i].score,&emp[i].yx,&emp[i].wd,&emp[i].mq);
}
}
void ana(Stu emp[MAX],int n)
{
int i;
for(i=0;i<n;i++)
{
if(emp[i].mon>80&&emp[i].mq=='Y')
emp[i].sum+=8000;
if(emp[i].mon>85&&emp[i].score>80)
emp[i].sum+=4000;
if(emp[i].mon>90)
emp[i].sum+=2000;
if(emp[i].mon>85&&emp[i].wd=='Y')
emp[i].sum+=1000;
if(emp[i].score>80&&emp[i].yx=='Y')
emp[i].sum+=850;
}
}
void prinf(Stu emp[MAX],int n)
{
int i,sum=0,max=0;
char e[40];
for(i=0;i<n;i++)
{
sum+=emp[i].sum; //累加求和;
}
for(i=n-1;i>=0;i=i-1)
{
if(emp[i].sum>=max)
{
max=emp[i].sum; //找最大值;
strcpy(e,emp[i].name) ;//找最大值对应的员工名字;
}
}
printf("%s\n%d\n%d",e,max,sum);
}