Openjudge1.9.08 白细胞计数

科技   2024-11-17 06:30   河北  

白细胞计数

【提交】

http://noi.openjudge.cn/ch0109/08/

【描述】

医院采样了某临床病例治疗期间的白细胞数量样本 份,用于分析某种新抗生素对该病例的治疗效果。为了降低分析误差,要先从这 份样本中去除一个数值最大的样本和一个数值最小的样本,然后将剩余 个有效样本的平均值作为分析指标。同时,为了观察该抗生素的疗效是否稳定,还要给出该平均值的误差,即所有有效样本(即不包括已扣除的两个样本)与该平均值之差的绝对值的最大值。

现在请你编写程序,根据提供的 个样本值,计算出该病例的平均白细胞数量和对应的误差。

【输入】

输入的第一行是一个正整数 ,表明共有 个样本。

以下共有 行,每行为一个浮点数,为对应的白细胞数量,其单位为 。数与数之间以一个空格分开。

【输出】

输出为两个浮点数,中间以一个空格分开。分别为平均白细胞数量和对应的误差,单位也是 。计算结果需保留到小数点后2位。

【样例输入】

5
12.0
13.0
11.0
9.0
10.0

【样例输出】

11.00 1.00

【提示】

为避免浮点精度误差过大,请使用double类型。

参考程序

C++版本

/*
* 08:白细胞计数
* http://noi.openjudge.cn/ch0109/08/
*/

#include<iostream>
#include<iomanip>
#include<cmath>
#include<algorithm>

using namespace std;

const int N = 305;
double arr[N];

int main()
{
    double sum = 0, avg = 0.0, max = 0.0;
    int n;
    cin >> n;
    for (int i = 0;i < n;i++)
    {
        cin >> arr[i];
    }
    sort(arr, arr + n);
    for (int i = 1;i < n - 1;i++)
    {
        sum += arr[i];
    }
    avg = sum / (n - 2);
    for (int i = 1;i < n - 1;i++)
    {
        double x = abs(arr[i] - avg);
        if (x > max)
        {
            max = x;
        }
    }
    cout << fixed << setprecision(2) << avg << " " << max;
    return 0;
}

青少年编程竞赛交流

「青少年编程竞赛交流群」已成立(适合6至18周岁的青少年),添加小助手微信,让他邀请大家进入学习群。进群之后大家可以参与定期组织的21天刷题打卡、等级考试测评、教育部白名单比赛辅导以及青少年编程组队竞赛等活动。

组队学习
分享组队学习的点点滴滴,和学习者一起成长!
 最新文章