程序设计 -- 去掉x个最高最低分后的平均分

期末考试结束了,小黄需要计算一下,本班同学们的语文成绩,如果去掉 x个最高分和 x个最低分,剩余同学的平均分是多少分,请你编程计算一下?
(先排序,然后把不是x个最高数和x个最低数加起来,求平均数)
输入格式
第一行有两个整数 n和x

n代表分数的总数, x代表要去掉的最高分和最低分的数量( 10 <= n <= 10000, x < n / 4)

第二行有 n个整数,代表 n个同学的分数

输出格式
n个分数去掉 x个最高分和 x个最低分后的平均分,结果保留 1位小数

输入样例
8 2
1 8 2 6 6 5 3 4
输出样例
4.5



```c++
#include<iostream>
#include<vector>
#include<iomanip>
using namespace std;
int main()
{
    vector<int>s;
    int n, x;
    cin >> n >> x;
    int min = 0, max = 0; double sum = 0;
    for (int i = 0; i < n; i++)
    {
        int m; cin >> m;
        s.push_back(m);
    }
    for (int i = 0; i < n-1; i++)
    {
        for (int j = 0; j < n - i - 1; j++)
        {
            if (s[j] < s[j+1]) 
            {
                int temp = s[j];
                s[j] = s[j+1];
                s[j+1] = temp;
            }
        }
    }
    for (int i = 0; i < x; i++)
    {
        s[i] = s[n - i - 1] = 0;
    }
    for (int i = 0; i < n; i++) { sum += s[i]; }
    sum=sum/(n-2*x);
    cout << setprecision(2) << sum << endl;
}

![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/543049440146149.png "#left")




#include<iostream>
using namespace std;
const int StuNum = 10;
double countavergescore(double * arr, int n);
int main()
{
double arr[StuNum];
cout << "Please enter " << StuNum << " specilist sores:\n";
int i = 0;
while (i < StuNum)
{
cin >> arr[i++];
cin.get();
}
cout << "\nThe averge sore is :" << countavergescore(arr, StuNum) << "\n";
return 0;
}
double countavergescore(double * arr, int n)
{
double max = arr[0];
double min = arr[0];
double sum = arr[0];
int i = 1,j=1;
for (;i<n;++i)
{
sum += arr[i];
if (arr[i]>max)
max = arr[i];
}
for (; j<n;++j)
{
if (arr[j]<min)
min = arr[j];
}
sum -= max;
sum -= min;
return sum / (n - 2);
}

输入的一列数字排序,循环x次每次将最低最高赋值为0,最后求和


#include <iostream>
#include <stdio.h>
using namespace std;
int main()
{
    int n, x, i, j, sum = 0;
    cin >> n >> x;
    int a[n];
    for (i = 0; i < n; i++)
    {
        cin >> a[i];
    }
    //排序
    for (i = 0; i < n - 1; i++)
    {
        for (j = 0; j < n - 1 - i; j++)
        {
            if (a[j] > a[j + 1])
            {
                int temp = a[j];
                a[j] = a[j + 1];
                a[j + 1] = temp;
            }
        }
    }
    for (i = x; i < n - x; i++)
    {
        sum += a[i];
    }
    cout << sum * 1.0 / (n - 2 * x) << endl;

    return 0;
}