感觉这道题文字游戏,还是我阅读能力差劲,给我整蒙了半天,最后求平均居然是求3的平均而不是5
题目
现在有 n(n \le 1000)n(n≤1000) 位评委给选手打分,分值从 0 到 10。需要去掉一个最高分,去掉一个最低分(如果有多个最高或者最低分,也只需要去掉一个),剩下的评分的平均数就是这位选手的得分。现在输入评委人数和他们的打分,请输出选手的最后得分,精确到 2 位小数。
输入
新手代码
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
int min,max,sum_all=0,sum_maxmin,a[1000],n,i;
float average;
cin>>n;
for( i=0;i<n;i++)
{
cin>>a[i];
}
min=max=a[0];
for( i=1;i<n;i++)
{
if(a[i]>max)
max=a[i];
if(a[i]<min)
min=a[i];
}
sum_maxmin=min+max;
for(i=0;i<n;i++)
{
sum_all+=a[i];
}
average=(sum_all-sum_maxmin)/(float)(n-2);
cout<<setprecision(2)<<fixed<<average;
return 0;
}
看到了一个不错的解法,就是用排序函数
#include<bits/stdc++.h>
using namespace std;
int n,a[10001];
double ans;
int main()
{
cin>>n;
for(int i=1;i<=n;i++) cin>>a[i];
sort(a+1,a+n+1);
for(int i=2;i<=n-1;i++) ans+=a[i];
printf("%.2lf",ans/(n-2));
return 0;
}