题目如下:
某销售公司在年末的时候会向员工发放红包,发放的红包金额共有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
代码如下:
#include <stdio.h>
#include <string.h>
struct people
{
char name[20];
int monscore;
int peoscore;
char good;
char home;
char appear;
int persum;
};
int main()
{
int n,sum=0,temp=0,max=0;
scanf("%d",&n);
struct people a[n];
for(int i=0;i<n;i++)
{
scanf("%s%d%d %c %c %c",a[i].name,&a[i].monscore,&a[i].peoscore,&a[i].good,&a[i].home,&a[i].appear);
}
for(int i=0;i<n;i++)
{
a[i].persum=0;
if(a[i].peoscore>80&&a[i].good=='Y')
{
a[i].persum+=850;
}
if(a[i].monscore>85&&a[i].home=='Y')
{
a[i].persum+=1000;
}
if(a[i].monscore>90)
{
a[i].persum+=2000;
}
if(a[i].monscore>85&&a[i].peoscore>80)
{
a[i].persum+=4000;
}
if(a[i].monscore>80&&a[i].appear=='Y')
{
a[i].persum+=8000;
}
sum+=a[i].persum;
if(a[i].persum>temp)
{
max=i;
temp=a[i].persum;
}
}
printf("%s\n",a[max].name);
printf("%d\n",a[max].persum);
printf("%d",sum);
return 0;
}
欢迎交流