|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 wyd264699424 于 2018-12-3 15:31 编辑
- #include<stdio.h>
- #include<stdlib.h>
- void main()
- { double fz=1.0,fm=1.0;
- int n=1;
- double e,num=1.0,test;
- scanf("%lf",&e);
- if (num<e)
- printf("1 2.0000000");
- else do
- { n++; fz*=(n-1);
- fm*=(2*n-1);
- test=fz/fm;
- num+=test;
- }while ((2*test)>=e);
- printf("%d %.7f",n,2*num);
- return;
- }
复制代码
问题:给定一个精度值e,用下列公式计算Π的近似值,要求前后两次Π的迭代之差的绝对值小于e,给出相应的最小迭代次数n和最后一次计算的Π的值。
Π/2=1+1!/3+2!/(3×5)+3!/(3×5×7)+...+(n-1)!/(3×5×7×...×(2n-1))
【输入形式】
从控制台输入e( e>=0.000001 )的值。
【输出形式】
输出迭代次数n和最后一次计算的Π的值(以一个空格分隔,并且输出Π时要求小数点后保留7位有效数字)。
【样例输入】
0.000003
【样例输出】
19 3.1415912
【样例说明】
输入的精度e为0.000003,当n为17时,计算的Π值为3.1415864,n为18时计算的π值为3.1415896,两者之差为0.0000032,大于给定的精度值,所以需要继续计算。当n为19时,计算的Π值为3.1415912,与上次之差为0.0000016,小于给定的精度值,所以最小迭代次数为19,输出的Π值为3.1415912。
注意:
(1) 为保证计算精度,请使用double数据类型保存计算数据。
(2) 应至少迭代两次,即:n>=2。
这里面有个累加值:num+=test,num是n项test值的总和。
Sn=a1+a2+a3+...+an;
Sn-1=a1+a2+a3+...+an-1;
Sn-Sn-1=an;
然后公式里的是PI/2,所以test要乘以2;
|
|