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

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

习题概述

题目描述

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

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

输入格式

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

输出格式

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

代码部分

#include<bits/stdc++.h>
using namespace std;

int main()
{
    float a;
    cin >> a ;
    printf("%.3f", float(a)); 
    return 0;
}

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

习题概述

题目描述

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

输入格式

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

输出格式

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

代码部分

#include<bits/stdc++.h>
using namespace std;

int main()
{
    long long a,b;
    cin>>a;
    cin>>b;
    cout<<a*b;
    return 0;
}

心得体会


day17-- 白细胞计数**--2.21**

习题概述

题目描述

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

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

输入格式

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

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

输出格式

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

代码表示

#include<bits/stdc++.h>
using namespace std;

int n;
double a[310];//浮点数数组,存储样本的白细胞数量
int main(){
	cin>>n;
	for(int i=1;i<=n;i++)
		cin>>a[i];
	sort(a+1,a+n+1);//使用 sort 函数对数组 a 进行升序排序
	double jas=0;//计数器
	for(int i=2;i<n;i++)
		jas+=a[i];
	cout<<fixed<<setprecision(2)<<jas/(n-2)<<" "//平均白细胞数量 
	<<max(fabs(a[2]-jas/(n-2)),fabs(a[n-1]-jas/(n-2)));//对应的误差
	return 0;
}

心得体会

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 是要排序的元素的数量。

  1. 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() 函数会返回这两个差的绝对值中的较大值。

相关推荐
Eoneanyna1 分钟前
QT设置git仓库
开发语言·git·qt
拥抱AGI2 分钟前
我说大模型微调没啥技术含量,谁赞成谁反对?
人工智能·学习·语言模型·大模型学习·大模型入门·大模型教程
+码农快讯+5 分钟前
Git入门学习(1)
git·学习·elasticsearch
小鹿( ﹡ˆoˆ﹡ )6 分钟前
Python中的树与图:构建复杂数据结构的艺术
开发语言·python
qmx_078 分钟前
MFC-基础架构
c++·mfc
万象.10 分钟前
STL_vector实现及干货以及vector迭代器失效问题
c++
想变成自大狂11 分钟前
C++中的异构容器
开发语言·c++
qq_1728055912 分钟前
GO GIN 推荐的库
开发语言·golang·gin
小米里的大麦15 分钟前
【C++】深入理解引用:从基础到进阶详解
c++·经验分享·笔记·引用·引用和指针
friklogff19 分钟前
【C#生态园】构建你的C#操作系统:框架选择与实践
服务器·开发语言·c#