C语言 运行结果中为什么双精度实型只输出小数点后六位
n/2=1+1/3+1/3*2/5+1/3*2/5*3/7....,当最后一项小于输入值的时候,输出n#include"stdio.h"doublepi(doubleep...
n/2=1+1/3+1/3*2/5+1/3*2/5*3/7....,
当最后一项小于输入值的时候,输出n
#include "stdio.h"
double pi(double eps)
{int i=1 ,j=3;
double t=1.0,p=1.0,pi;
while(t>=eps)
{t=t*i/j;
p+=t;
i++;
j+=2;
}
pi=p*2;
return pi;
}
main()
{double p,eps;
scanf("%lf",&eps);
p=pi(eps);
printf("%lf",p);
}
一个常见的题目,为什么我运行了之后输入的数再小,输出也只是3.141590,双精度应该可以输出更多位小数的 啊?
图片审核的时间太久了,还没出来。
问题是:比如我在输入0.0000000000000000000000000000000000000001的时候,输出的结果是35.134971,请问这是为什么? 展开
当最后一项小于输入值的时候,输出n
#include "stdio.h"
double pi(double eps)
{int i=1 ,j=3;
double t=1.0,p=1.0,pi;
while(t>=eps)
{t=t*i/j;
p+=t;
i++;
j+=2;
}
pi=p*2;
return pi;
}
main()
{double p,eps;
scanf("%lf",&eps);
p=pi(eps);
printf("%lf",p);
}
一个常见的题目,为什么我运行了之后输入的数再小,输出也只是3.141590,双精度应该可以输出更多位小数的 啊?
图片审核的时间太久了,还没出来。
问题是:比如我在输入0.0000000000000000000000000000000000000001的时候,输出的结果是35.134971,请问这是为什么? 展开
5个回答
展开全部
在C语言中,输出double类型(双精度实型)以及float类型(单精度实型)时,默认输出6位小数。
比如这样的代码:
double a = 1;
printf("%lf\n", a);
输出会是
1.000000
但是有时六位会显得很长,没必要。比如计算平均分,一到两位小数就足够了。
可是有时六位又不够,需要更多位小数,比如计算高精度平方根。
这时可以用printf的格式控制。
如果要输出n位小数,那么可以用%.nlf的格式。其中n为数字。
如要输出10位小数,那么
printf("%.10lf\n", a);
即可
类似的输出1位小数
printf("%.1lf\n", a);
展开全部
printf("%lf",p);
是一般输出形式默认是 6位吧
你 试试
printf("%.10f",p);
也许就 可以了
是一般输出形式默认是 6位吧
你 试试
printf("%.10f",p);
也许就 可以了
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
只输出六位小数,这是默认的,可以改变,如:printf("%6",d)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
楼上的回答是对的,printf要求你输出格式,默认6位小数,你可以指定输出几位
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你可以自己设置输出精度的
printf("%.nf",p); n为你的精度
如:printf("%.6f",p); //输出为小数点后6位
printf("%.nf",p); n为你的精度
如:printf("%.6f",p); //输出为小数点后6位
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询