英文金曲大赛 SDUT OJ C语言 1121

英文金曲大赛

Time Limit: 1000 ms Memory Limit: 65536 KiB

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>

int main()
{
    int i;
    double a[8],ave,max,min,h;
    char name[31];
    while(~scanf("%lf",&a[0]))
    {
        h=a[0];//最开始和为零
        for(i=1; i<7; i++)
        {
            scanf("%lf",&a[i]);
            h=h+a[i];//采用计算全部和再减去最大值最小值的方式
        }
        scanf("%s",name);
        max=min=a[0];
        for(i=1; i<7; i++)
        {
            if(max<=a[i])
                max=a[i];
            if(min>=a[i])
                min=a[i];//无需排序只需要找出最大和最小
        }
        ave=(h-max-min)/5;//全部和再减去最大值最小值求平均
        printf("%s %.2lf\n",name,ave);
    }
    return 0;
}
注释:ACM里面的题是要用结构体的,只需把一个人的评分、最大值、最小值信息放在一个结构体之中

猜你喜欢

转载自blog.csdn.net/qq_40354578/article/details/81346927