C语言里,double类型的数据可以精确到小数点后几位?
Linux32位环境下,C语言,gcc编译的,不是说double是精确到16位的吗,但我这里只显示了6位,doublea=1.0000019;printf(“%lf”,a...
Linux32位环境下,C语言,gcc编译的,不是说double是精确到16位的吗,但我这里只显示了6位,double a=1.0000019;printf(“%lf”,a),输出1.000001;再多一位就直接自动四舍五入了,初学者求助。
问1:为什么只显示了6位,而不是书上说的16位?
问2:为什么会自动四舍五入,如何不让他四舍五入? 展开
问1:为什么只显示了6位,而不是书上说的16位?
问2:为什么会自动四舍五入,如何不让他四舍五入? 展开
5个回答
展开全部
C语言里面,默认%f是小数点后6位,如果想小数点后面16位,写成%.16lf,不会自动四舍五入的,double是一个近似值,通常没有办法做的很精确。通常能精确到小数点后面5,6位,也就是说超过5,6位了可能就不准了。
1、double f = 111231.5585; BigDecimal b = new BigDecimal(f); double f1 = b.setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue(); 。
2、new java.text.DecimalFormat("#.00").format(3.1415926)
3、C风格,最方便,double d = 3.1415926;String result = String .format("%.2f", d); String .format("%-10.2f", d);
4、NumberFormat ddf1=NumberFormat.getNumberInstance() ; void setMaximumFractionDigits(int digits)。
展开全部
C语言里面,默认%f是小数点后6位,如果想小数点后面16位,写成%.16lf
不会自动四舍五入的,double是一个近似值,通常没有办法做的很精确.
通常能精确到小数点后面5,6位,也就是说超过5,6位了可能就不准了。
不会自动四舍五入的,double是一个近似值,通常没有办法做的很精确.
通常能精确到小数点后面5,6位,也就是说超过5,6位了可能就不准了。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
"%lf"默认只显示6位小数,如果想显示更多请指定:例如"%0.16lf"
精度位不够自动四舍五入,没办法去掉。只有增加精度显示
精度位不够自动四舍五入,没办法去掉。只有增加精度显示
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-08-22
展开全部
十进制的15或16位有效数字,因此精确到小数点后最多有15或16位。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个我记得跟系统的位数有关吧,还有你是以lf 的格式打印出来的,这2个一样吗?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询