当前位置:   article > 正文

洛谷C++简单题小练习day17—输出保留 3 位小数的浮点数, A*B 问题,白细胞计数三个小程序

洛谷C++简单题小练习day17—输出保留 3 位小数的浮点数, A*B 问题,白细胞计数三个小程序

day17--输出保留 3 位小数的浮点数--2.21

习题概述

题目描述

读入一个单精度浮点数,保留 3 位小数输出这个浮点数。

提示:就这题来说,请使用 float 类型的单精度浮点数。

输入格式

只有一行,一个单精度浮点数。

输出格式

也只有一行,读入的单精度浮点数。

代码部分

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int main()
  4. {
  5. float a;
  6. cin >> a ;
  7. printf("%.3f", float(a));
  8. return 0;
  9. }

 day17-- A*B 问题类型问题--2.21

习题概述

题目描述

输入两个正整数 A 和 B,求 A×B 的值。注意乘积的范围和数据类型的选择。

输入格式

一行,包含两个正整数 A 和 B,中间用单个空格隔开。1≤A,B≤50000。

输出格式

一个整数,即 A×B 的值。

代码部分

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int main()
  4. {
  5. long long a,b;
  6. cin>>a;
  7. cin>>b;
  8. cout<<a*b;
  9. return 0;
  10. }

心得体会 


 day17--白细胞计数--2.21

习题概述

题目描述

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

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

输入格式

输入的第一行是一个正整数 n(2<n≤300),表明共有 n 个样本。

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

输出格式

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


代码表示  

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int n;
  4. double a[310];//浮点数数组,存储样本的白细胞数量
  5. int main(){
  6. cin>>n;
  7. for(int i=1;i<=n;i++)
  8. cin>>a[i];
  9. sort(a+1,a+n+1);//使用 sort 函数对数组 a 进行升序排序
  10. double jas=0;//计数器
  11. for(int i=2;i<n;i++)
  12. jas+=a[i];
  13. cout<<fixed<<setprecision(2)<<jas/(n-2)<<" "//平均白细胞数量
  14. <<max(fabs(a[2]-jas/(n-2)),fabs(a[n-1]-jas/(n-2)));//对应的误差
  15. return 0;
  16. }

心得体会 

1.sort() 是 C++ 标准库 `<algorithm>` 中提供的一个排序函数。它可以对容器或数组中的元素进行排序。sort() 函数的基本用法是:
sort(first, last);
- first:表示要排序的起始位置的迭代器。
- last:表示排序的结束位置的迭代器(不包含)。

sort() 函数将会按照默认的升序规则对指定范围内的元素进行排序。如果要对自定义类型的容器或数组进行排序,需要确保该类型支持 `<` 运算符或传入自定义的比较函数。

除了基本用法外,sort()函数还可以接受第三个参数,用于指定自定义的比较函数,从而实现按照特定的排序规则进行排序。

例如,可以这样使用自定义的比较函数对容器进行降序排序:
bool compare(int a, int b) {
    return a > b;
}

vector<int> nums = {5, 2, 8, 1, 3};
sort(nums.begin(), nums.end(), compare);

需要注意的是,sort() 函数的时间复杂度为 O(n log n),其中 n 是要排序的元素的数量。

2. max(fabs(a[2]-jas/(n-2)),fabs(a[n-1]-jas/(n-2))); 解析如下

1) fabs() 函数:这是 C++ 标准库 <cmath> 中提供的函数,用于计算一个数的绝对值。它接受一个浮点数或双精度数作为参数,并返回该数的绝对值。

2) a[2]:这是数组 a 的第二个元素。

3) jas/(n-2):这是一个数值计算,其中 jas 是某个变量或常量,而 (n-2) 表示数组 a 中有效元素的数量减去 2。

现在我们来整体理解这个表达式:

·表达式中的 fabs(a[2]-jas/(n-2)) 计算了数组 a 的第二个元素与 jas/(n-2) 的差的绝对值。

·表达式中的 fabs(a[n-1]-jas/(n-2)) 计算了数组 a 的倒数第二个元素与 jas/(n-2) 的差的绝对值。

·接着 max() 函数会返回这两个差的绝对值中的较大值。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/140955
推荐阅读
相关标签
  

闽ICP备14008679号