早教吧作业答案频道 -->其他-->
编写函数fun,其功能是:根据以下公式求π的值(要求精度0.0005,即某项小于0.0005时停止迭代).请编写函数fun,其功能是根据以下公式求π的值(要求满足精度0.0005,即某项小于0.0005时停止迭代).π/2
题目详情
编写函数fun,其功能是:根据以下公式求π的值(要求精度0.0005,即某项小于0.0005时停止迭代).
请编写函数fun,其功能是根据以下公式求π的值(要求满足精度0.0005,即某项小于0.0005时停止迭代).
π/2=1+1/3+(1*2)/(3*5)+(1*2*3)/(3*5*7)+……+(1*2*3*4*……*n)/(3*5*7*……*(2n+1))
程序运行后,若输入精度为0.0005,则输出为3.1416
#include
#include
double fun ( double eps)
{ double pi=0,a=1,i;
for(i=1;a>=eps;i++){
pi=pi+a;
a=a*i/(2*i+1);
}
return 2*pi;
}
main( )
{ double x;void NONO ();
printf("Input eps:") ;
scanf("%lf",&x); printf("\neps = %lf,PI=%lf\n",x,fun(x));
NONO();
}
double fun ( double eps)
{ double s=1.0,s1=1.0; int n=1;
while(s1>=eps) /*当某项大于精度要求时,继续求下一项*/
{s1=s1*n/(2*n+1); /*求多项式的每一项*/
s=s+s1; /*求和*/
n++; } return 2*s; }
请编写函数fun,其功能是根据以下公式求π的值(要求满足精度0.0005,即某项小于0.0005时停止迭代).
π/2=1+1/3+(1*2)/(3*5)+(1*2*3)/(3*5*7)+……+(1*2*3*4*……*n)/(3*5*7*……*(2n+1))
程序运行后,若输入精度为0.0005,则输出为3.1416
#include
#include
double fun ( double eps)
{ double pi=0,a=1,i;
for(i=1;a>=eps;i++){
pi=pi+a;
a=a*i/(2*i+1);
}
return 2*pi;
}
main( )
{ double x;void NONO ();
printf("Input eps:") ;
scanf("%lf",&x); printf("\neps = %lf,PI=%lf\n",x,fun(x));
NONO();
}
double fun ( double eps)
{ double s=1.0,s1=1.0; int n=1;
while(s1>=eps) /*当某项大于精度要求时,继续求下一项*/
{s1=s1*n/(2*n+1); /*求多项式的每一项*/
s=s+s1; /*求和*/
n++; } return 2*s; }
▼优质解答
答案和解析
无论是你的答案还是正确答案 都有问题
你的答案 问题在于自变量i设置成了double型
浮点型 做自加操作的时候可能导致死循环的 也就是你的程序 如果精度设置的特别高会出问题
所谓的正确答案,没有这个问题 但是不符题意
即某项小于0.0005时停止迭代
正确答案中是某项小于精度后 把该项累加并在下一项停止迭代
下面是把你的程序改成了完全符合“正确答案”的代码
PS:题目中也有一个错误 当精度为0.0005时 输出的是3.141106 即保留四位小数位3.1411
要想输出3.1416 最低精度为0.00002
#include
double fun ( double eps)
{ double pi=1,a=1;
\x09int i;
for(i=1;a>=eps;i++){
a=a*i/(2*i+1);
pi=pi+a;
}
return 2*pi;
}
main( )
{ double x;
printf("Input eps:") ;
scanf("%lf",&x); printf("\neps = %lf, PI=%.4lf\n", x, fun(x));//输出4位小数
}
你的答案 问题在于自变量i设置成了double型
浮点型 做自加操作的时候可能导致死循环的 也就是你的程序 如果精度设置的特别高会出问题
所谓的正确答案,没有这个问题 但是不符题意
即某项小于0.0005时停止迭代
正确答案中是某项小于精度后 把该项累加并在下一项停止迭代
下面是把你的程序改成了完全符合“正确答案”的代码
PS:题目中也有一个错误 当精度为0.0005时 输出的是3.141106 即保留四位小数位3.1411
要想输出3.1416 最低精度为0.00002
#include
double fun ( double eps)
{ double pi=1,a=1;
\x09int i;
for(i=1;a>=eps;i++){
a=a*i/(2*i+1);
pi=pi+a;
}
return 2*pi;
}
main( )
{ double x;
printf("Input eps:") ;
scanf("%lf",&x); printf("\neps = %lf, PI=%.4lf\n", x, fun(x));//输出4位小数
}
看了编写函数fun,其功能是:根据...的网友还看了以下:
已知b是最小的正整数、且a、b满足(c-5)的平方+|a+b|=0、请直接写出a、b、c、的值、2 2020-05-13 …
摄氏温度规定冰水混合物的温度为0摄氏度,即在环境温度高于和低于0℃时,冰水混合物的温度总是0℃。请 2020-06-10 …
已知:a=-1,b=1,c=5.a,b,c所对应的点分别A,B,C.为点P为易动点,其对应的数为x 2020-06-12 …
电影《红河谷》里有这样一个镜头:一位藏族人带领两位英国人通过大雪山进藏,路上,英国人拔出手枪准备朝 2020-06-18 …
r=2acosA,请问如果要积分求面积的话,A的范围即上下限应该是什么呢?还想请问下,既然是圆的话 2020-07-13 …
小燕子竟然推导出了0>5的错误结论.请你仔细阅读她的推导过程,指出问题到底出在哪里?已知x>y,两边 2020-10-31 …
对于任意自然数n,定义:△n为不超过n的所有自然数之和的个位数字,例如△4表示0+1+2+3+4=1 2020-11-11 …
商店里有100w(即0.1kw)的白炽灯和40w(即0.04kw)的节能灯,单价分别为2元和32元. 2020-11-14 …
0>4,哪里错了?已知m>n,两边都乘以4,的4m>4n,①两边都减去4m,得0>4n-4m②即0> 2020-12-12 …
合作题:循环小数0.3,可化为分数,设x=0.3,则10x=3+0.3,10x=3+x,9x=3,所 2021-01-22 …