某销售公司在年末的时候会向员工发放红包,发放的红包金额共有5种,获取的条件各不相同

某销售公司在年末的时候会向员工发放红包,发放的红包金额共有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);

}

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值