sdut oj C语言结构体 英文金曲大赛

版权声明:本人原创文章若需转载请标明出处和作者!沙沙 https://blog.csdn.net/weixin_44143702/article/details/86498168

英文金曲大赛

Time Limit: 1000 ms Memory Limit: 65536 KiB

Submit Statistic

Problem Description

我们在“渊子数”的题目中已经了解了渊子是个什么样的人了,他在大一的时候参加过工商学院的“英语聚乐部”。告诉你个秘密,这个俱乐部是个好地方,不但活动精彩而且有MM。
这不,英语俱乐部举办了一个叫做“英文金曲大赛”的节目。这个节目有好多人参加,这不,成绩出来了,渊子当是很勇敢,自告奋勇接下了算出大家的总得分的任务。 
当时有7个评委,每个评委都要给选手打分,现在要求去掉一个最高分和去掉一个最低分,再算出平均分。结果精确到小数点后两位。

Input

测试数据包括多个实例。
每组数据包括7个实数,代表评委们对该选手的评分。紧接着是选手的名字,名字的长度不超过30个字符,且没有空格。 
输入直到文件结束。

Output

算出每位选手名字和最终得分,结果保留两位小数。

Sample Input

10 10 10 10 10 10 9 xiaoyuanwang
0 0 0 0 0 0 0 beast

Sample Output

xiaoyuanwang 10.00
beast 0.00
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct
{
    int score[7];
    char name[40];
    double lasts;//最终的平均分
}a;

int main()
{
    int i, sum, max, min, x, y;
    double ave;
    while(~scanf("%d", &a.score[0]))
    {
        max = a.score[0];
        min = a.score[0];
        x = y = -1;//记录最高分和最低分的下标
        sum = ave = 0;
        for(i = 1; i < 7; i++)
        {
            scanf("%d", &a.score[i]);
            sum += a.score[i];
            if(max < a.score[i])
            {
                max = a.score[i];
                x = i;
            }
            if(min > a.score[i])
            {
                min = a.score[i];
                y = i;
            }
        }
        scanf("%s", a.name);
        for(i = 0; i < 7; i++)
        {
            if(i == x)  sum -= a.score[i];
            if(i == y)  sum -= a.score[i];
        }//去掉最高分和最低分
        ave = sum / 5.0;//此处是除以5!!!不要除7
        a.lasts = ave;
        printf("%s %.2lf\n", a.name, a.lasts);
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/weixin_44143702/article/details/86498168