C语言解答:利用公式:π/4=1-1/3+1/5-1/7+……,求π的近似值,直到最后一项的绝对值小于10-6为止
利用公式:π/4=1-1/3+1/5-1/7+……,求π的近似值,直到最后一项的绝对值小于10-6为止下面是我写的,运行显示pi是4.00000000000,明显不对。。...
利用公式:π/4=1-1/3+1/5-1/7+……,求π的近似值,直到最后一项的绝对值小于10-6为止 下面是我写的,运行显示pi 是4.00000000000,明显不对。。又不知道哪里错了。
#include<stdio.h>#include<math.h>void main(){double s=0,pi,t,d,c;int i,n,j=1;for(i=2,n=1;fabs(1/n)>pow(10,-6);i++,n+=2)s=s+pow(-1,i)*j/n;printf("%f\n",s);printf("pi=%f\n",pi=s*4);}
#include<stdio.h>
#include<math.h>
void main()
{
double s=0,pi,t,d,c;
int i,n,j=1;
for(i=2,n=1;fabs(1/n)>pow(10,-6);i++,n+=2)
s=s+pow(-1,i)*j/n;
printf("%f\n",s);
printf("pi=%f\n",pi=s*4);
} 展开
#include<stdio.h>#include<math.h>void main(){double s=0,pi,t,d,c;int i,n,j=1;for(i=2,n=1;fabs(1/n)>pow(10,-6);i++,n+=2)s=s+pow(-1,i)*j/n;printf("%f\n",s);printf("pi=%f\n",pi=s*4);}
#include<stdio.h>
#include<math.h>
void main()
{
double s=0,pi,t,d,c;
int i,n,j=1;
for(i=2,n=1;fabs(1/n)>pow(10,-6);i++,n+=2)
s=s+pow(-1,i)*j/n;
printf("%f\n",s);
printf("pi=%f\n",pi=s*4);
} 展开
3个回答
展开全部
#include<stdio.h>
#include<math.h>
void main()
{
double s=0,pi,t,d,c;
double i,n,j=1; //这里都修改为double
for(i=2,n=1;fabs(1/n)>pow(10,-6);i++,n+=2)
s=s+pow(-1,i)*j/n; //否者这里是整形的除法,会对结果取整
printf("%lf\n",s); //由于s是double,所以应该用%lf
printf("pi=%lf\n",pi=s*4);
}
展开全部
//加上强制类型转换
#include<stdio.h>
#include<math.h>
void main()
{
double s=0,pi,t,d,c;
int i,n,j=1;
for(i=2,n=1;fabs(1/(double)n)>pow(10,-6);i++,n+=2)
s=s+pow(-1,i)*j/(double)n;
printf("%lf\n",s);
printf("pi=%lf\n",pi=s*4);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
int main()
{
double k=1.0,y,x=0.0;
int i=1;
do{
y=1.0/(2*i++-1);
x+=k*y;
k=-k;
}while(y>=0.000001);
printf("pi=%10.9lf",4.0*x);
return 0;
}
int main()
{
double k=1.0,y,x=0.0;
int i=1;
do{
y=1.0/(2*i++-1);
x+=k*y;
k=-k;
}while(y>=0.000001);
printf("pi=%10.9lf",4.0*x);
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询