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

相关推荐
@大迁世界1 分钟前
构建 Next.js 应用时的安全保障与风险防范措施
开发语言·前端·javascript·安全·ecmascript
a_j581 小时前
算法与数据结构(环形链表)
数据结构·链表
paterWang1 小时前
基于 SSM框架 的 “捷邻小程序” 系统的设计与实现
小程序
攻城狮7号1 小时前
【第四节】C++设计模式(创建型模式)-Builder(建造者)模式
c++·设计模式·建造者模式
Vin__1 小时前
微信小程序客服消息接收不到微信的回调
spring boot·微信小程序·小程序
fpcc1 小时前
设计心得——解耦的实现技术
c++·软件工程
水瓶丫头站住1 小时前
Qt中QRadioButton的样式设置
开发语言·qt
东方芷兰2 小时前
算法笔记 04 —— 算法初步(下)
c++·笔记·算法
JNU freshman2 小时前
图论 之 迪斯科特拉算法求解最短路径
算法·图论
lvbb662 小时前
微信小程序-二维码绘制
微信小程序·小程序