2 daxiangele1 daxiangele1 于 2016.01.20 11:31 提问

关于float类型的有效数字,C语言

C语言float类型的有效数字不是16位么?为什么金牌大试卷的答案上说是6位?印错了?

4个回答

91program
91program   Ds   Rxr 2016.01.20 11:56

float 类型小数点后有效位的位数是 6.Double 的 是 15 位。

91program
91program   Ds   Rxr 2016.01.20 11:57
caozhy
caozhy   Ds   Rxr 2016.01.20 11:33

http://blog.sina.com.cn/s/blog_6ebd49350101gdgo.html

float和double的精度是由尾数的位数来决定的。浮点数在内存中是按科学计数法来存储的,其整数部分始终是一个隐含着的“1”,由于它是不变的,故不能对精度造成影响。float:2^23 = 8388608,一共七位,这意味着最多能有7位有效数字,但绝对能保证的为6位,也即float的精度为6~7位有效数字

John_ToStr
John_ToStr   Rxr 2016.01.23 16:47

caozhy  解释的很清楚了, 总之就是方便编译器处理

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!