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

相关推荐
扫地的小何尚3 分钟前
NVIDIA RTX PC开源AI工具升级:加速LLM和扩散模型的性能革命
人工智能·python·算法·开源·nvidia·1024程序员节
薛不痒25 分钟前
深度学习之优化模型(数据预处理,数据增强,调整学习率)
深度学习·学习
wanglei20070830 分钟前
生产者消费者
开发语言·python
leo__5201 小时前
基于菲涅耳衍射积分的空心高斯光束传输数值模拟(MATLAB实现)
开发语言·matlab
昵称已被吞噬~‘(*@﹏@*)’~1 小时前
【RL+空战】学习记录03:基于JSBSim构造简易空空导弹模型,并结合python接口调用测试
开发语言·人工智能·python·学习·深度强化学习·jsbsim·空战
短剑重铸之日1 小时前
《SpringBoot4.0初识》第一篇:前瞻与思想
java·开发语言·后端·spring·springboot4.0
苦藤新鸡1 小时前
8.最长的无重复字符的子串
c++·力扣
千金裘换酒1 小时前
LeetCode反转链表
算法·leetcode·链表
我想我不够好。1 小时前
学到的知识点 1.8
学习
2501_941877981 小时前
从配置热更新到运行时自适应的互联网工程语法演进与多语言实践随笔分享
开发语言·前端·python