牛客网NC22157:牛牛学数列2

牛客网NC22157:牛牛学数列2

📝 题目描述

🔍 输入输出说明

输入描述

  • 输入一个整数 N,范围在 0 到 1000

输出描述

  • 输出一个保留6位小数的浮点数

示例

  • 输入:2
  • 输出:1.500000

💡 解题思路

这是一个经典的调和级数求和问题。调和级数是形如 1 + 1/2 + 1/3 + ... + 1/n 的级数。

解题思路非常直接:

  1. 读取输入的整数 N
  2. 使用循环从 1 到 N,累加每一项 1/i 的值
  3. 按照要求格式输出结果(保留6位小数)

✅ 代码实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int main(){
    int n;
    cin >> n;
    double s = 0; // 初始化求和变量
    
    // 循环累加每一项
    for(int i = 1; i <= n; i++)
        s += 1.0 / i;//注意使用 `1.0` 而不是 `1`,确保进行浮点数除法
    
    // 按要求格式输出
    printf("%.6f", s);
    return 0;
}

📌 代码详解

  1. #include<bits/stdc++.h> - 包含了大部分常用的C++标准库,简化了引入头文件的过程
  2. 定义整数变量 n 接收输入
  3. 定义 double 类型变量 s 用于存储求和结果
  4. 使用 for 循环从 1 到 n 遍历,累加 1/i 项
    • 注意使用 1.0 而不是 1,确保进行浮点数除法
  5. 使用 printf("%.6f", s) 输出结果并保留6位小数

🔖 知识点总结

  1. 调和级数:形如 1 + 1/2 + 1/3 + ... + 1/n 的级数
  2. 浮点数精度控制 :使用 printf("%.6f", s) 控制输出的小数位数
  3. 类型转换 :使用 1.0 确保浮点数除法,避免整数除法截断

📚 拓展思考

当 N 非常大时,调和级数的增长非常缓慢,这是一个发散级数,但发散速度很慢。实际上,调和级数与自然对数有密切关系,当 N 趋向无穷大时,其近似值为 ln(N) + γ,其中 γ ≈ 0.57721 是欧拉常数。

在实际编程中,当 N 很大时,可能需要考虑精度和溢出问题,但本题中 N 最大为 1000,使用 double 类型足以满足要求。


希望这篇详解对你有所帮助!如有疑问,欢迎在评论区留言交流。

相关推荐
R-G-B3 分钟前
【04】OpenCV C++实战篇——实战:发票精准定位,提取指定单元格数据。(倾角计算、旋转矫正、产品定位、目标定位、OCR文字提取)
c++·opencv·ocr·发票精准定位·提取指定单元格数据·倾角计算·旋转矫正
teeeeeeemo18 分钟前
一些js数组去重的实现算法
开发语言·前端·javascript·笔记·算法
稚肩1 小时前
如何在linux中使用Makefile构建一个C++工程?
linux·运维·c++
啊森要自信1 小时前
【QT】常⽤控件详解(七)容器类控件 GroupBox && TabWidget && 布局管理器 && Spacer
linux·开发语言·c++·qt·adb
harykali2 小时前
DatawhaleAI夏令营:语音生成方向Task2从理解Baseline到系统调优
算法
teeeeeeemo2 小时前
JS实现数组扁平化
开发语言·前端·javascript·笔记·算法
源代码•宸2 小时前
C++高频知识点(二十)
开发语言·c++·经验分享·epoll·拆包封包·名称修饰
CoovallyAIHub2 小时前
雾天、夜晚都能识别?MEIWVD数据集+MSG-Net攻克内河航道检测三大难关
深度学习·算法·计算机视觉
重启的码农2 小时前
ZeroTier 源码解析 (2) 节点 (Node)
c++·网络协议