数学发展历史上,圆周率的计算曾有许多有趣甚至是传奇的故事。其中许多方法都涉及无穷级数。
图1.png中所示,就是一种用连分数的形式表示的圆周率求法。
下面的程序实现了该求解方法。实际上数列的收敛对x的初始值 并不敏感。
结果打印出圆周率近似值(保留小数点后4位,并不一定与圆周率真值吻合)。
double x = 111;
for(int n = 10000; n>=0; n--){
int i = 2 * n + 1;
x = 2 + (i*i / x);
}
System.out.println(String.format("%.4f", ______________));//填空
这个题,我第一眼没看懂,但是看程序,x不就是最终值嘛,直接填了 4 / x;
但是错了错了。
这还是得从读程序做起,
图上的式子让我看着眼花缭乱,该从何看起,看了许久还是不会,最终妥协,找了别人的观点。
就是从整体考虑的一个思路,先不管左边的1,把右边分数的分母看为一个整体,分母是2 + 奇数的平方除以上一个分母,用代码表示。
x = 2 + pow(n,2) / x;
一看这个代码和题目给的已经很像了,而题目中多了求奇数的过程而已,再加一个for循环。、
其实看代码会有一个细节,for循环是从10000开始的,因为我们的分母是从最下面向上逐渐变化的,也就是从10000开始的,那么当n = 0,时,最后
x = 2 + 1 / x;
但实际应该是
x = 1 + 1 / x;
所以在最后x应该减1.
所以填空是 4 / (x - 1);