ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

调和级数

2021-05-24 13:02:49  阅读:163  来源: 互联网

标签:%. 10000 int double 调和级数 printf kase


公式:f(n)=ln(n)+C+1/(2*n)

当n < 10000时,直接算,大于10000时用公式,其中C≈0.57721566490153286060651209

#include<bits/stdc++.h>
using namespace std;
const double r = 0.57721566490153286060651209;
double a[10000];

int main() {
    a[1] = 1;
    for (int i = 2; i < 10000; i++) {
        a[i] = a[i - 1] + 1.0 / i;
    }
    int n;
    cin >> n;
    for (int kase = 1; kase <= n; kase++) {
        int n;
        cin >> n;
        if (n < 10000) {
            printf("Case %d: %.10lf\n", kase, a[n]);
        } else {
            double a = log(n) + r + 1.0 / (2 * n);
            // double a=log(n+1)+r;
            printf("Case %d: %.10lf\n", kase, a);
        }
    }
    return 0;
}

  

标签:%.,10000,int,double,调和级数,printf,kase
来源: https://www.cnblogs.com/qq1415584788/p/14803895.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有