标题:计算Π的近似值
只看楼主
学会代码
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2020-12-8
结帖率:0
已结贴  问题点数:10 回复次数:2 
计算Π的近似值
已知∑∞ n=1,1/𝑛2 =𝜋2/6   。编写函数,利用该公式编程计算π的近似值,看
用这个和式的前多少项求出的近似值与 3.14159265 的误差小于 10-5,令函数输
出三项数据:计算得到的和,由这个和求出的π的近似值,得到这个和所用的项
数。函数原型为 void ComputePi( ),在主程序中调用 ComputePi 函数进行计算和
结果输出。
搜索更多相关主题的帖子: π 计算 void 近似 函数 
2020-12-16 23:23
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:10 
已知∑∞ n=1,1/𝑛2 =𝜋2/6   。
拷贝粘贴后,楼主自己都懒得看一眼

题目本身也挺怪诞的

因为 ∑(1/n^2) = 𝜋^2 / 6
所以 𝜋 = sqrt( 6 * ∑(1/n^2) )

题目要求“近似值与 3.14159265 的误差小于 10^-5”
因为 ∑(1/n^2) 是递增函数,
所以即要求 sqrt( 6 * ∑(1/n^2) ) > 3.14159265 - 10^-5
也就是 ∑(1/n^2) > (3.14159265 - 10^-5)^2 / 6;

程序代码:
#include <stdio.h>
#include <math.h>

int main( void )
{
    const double e = (3.14159265 - 1e-5)*(3.14159265 - 1e-5) / 6;

    double sum = 0;
    unsigned n = 0;
    for( n=0; sum<=e; ++n )
        sum += 1.0/(n+1)/(n+1);

    double pi = sqrt( 6*sum );
    printf( "sum = %f\n", sum );
    printf( "pi = %f\n", pi );
    printf( "item count = %u\n", n );
}


输出
sum = 1.644924
pi = 3.141583
item count = 95459
2020-12-17 13:02
学会代码
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2020-12-8
得分:0 
回复 2楼 rjsp
感谢 啊啊啊
javascript:insertText('19','em');
2020-12-17 16:46



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-504289-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.051567 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved