1261: 演讲大赛评分
描述
题目描述:
最近"老王"很开心.他在大一的时候参加过数计学院的“软件小组”。告诉你个秘密,这个小组是个好地方,不但活动精彩而且有MM。
这不,这个小组举办了一个叫做“计算机演讲大赛”的节目。这个节目有好多人参加,这不,成绩出来了,"老王"当是很勇敢,自告奋勇接下了算出大家的总得分的任务。
当时有7个评委,每个评委都要给选手打分,现在要求去掉一个最高分和去掉一个最低分,再算出平均分。结果精确到小数点后两位。
输入:
测试数据包括多个实例。
每组数据包括7个实数,代表评委们对该选手的评分。紧接着是选手的名字,名字的长度不超过30个字符。
输入直到文件结束。
输出:
算出每位选手名字和最终得分,结果保留两位有效数字
样例输入
10 10 10 10 10 10 9 xiaoyuanwang
0 0 0 0 0 0 0 beast
样例输出
xiaoyuanwang 10.00
beast 0.00
东秦的题目有一个特点就是样例很简单,而且经常会不给出真正要测试的点,我做这道题的时候脑子进水了,想到用结构体,但是想到的是a1,a2,,,a6,但是一想到这样的话没办法循环就用了整型数组做而不用结构体,没想起来在结构体中定义一个数组,还忽略了实数不是整数,这可能与样例中都是整数而没有小数点所造成的,不能盲目相信样例!!
#include<stdio.h>
typedef struct cc
{
/* int a1;
int a2;
int a3;
int a4;
int a5;
int a6;
int a7;*/
double a[7];//审题,是7个实数
char name[33];
double max;
double min;
}score;
int main()
{
int i,n;
float r,sum;
score t;
//int a[7];
while(scanf("%lf %lf %lf %lf %lf %lf %lf %s",&t.a[0],&t.a[1],&t.a[2],&t.a[3],&t.a[4],&t.a[5],&t.a[6],&t.name)!=EOF)
{
sum=0;
t.max=-1;
t.min=9999;
for(i=0;i<7;i++)
{
sum+=t.a[i];
if(t.a[i]>t.max)
{
t.max=t.a[i];
}
if(t.a[i]<t.min)
{
t.min=t.a[i];
}
}
r=(sum-t.max-t.min)/5.0;//34 66 78 89 54 13 93 wangfei 注意分母必须也是浮点数,否则答案永远是整除!!
printf("%s %.2f\n",t.name,r);
}
}
通过率
通过的数据:
结果 | 耗时 | 内存 |
---|---|---|
通过 | 0 | 1536000 |
通过 | 0 | 1519616 |
未通过的数据: