编程语言
首页 > 编程语言> > python – 为什么(0.0006 * 100000)?是10

python – 为什么(0.0006 * 100000)?是10

作者:互联网

当我做的时候(0.0006 * 100000)?和(0.0003 * 100000)?在python中它分别返回9.999999999999993,但实际上它必须为0.
同样在c fmod(0.0003 * 100000,10)中给出的值为10.有人可以帮我解决我出错的地方.

解决方法:

最接近的IEEE 754 64位二进制数为0.0003是0.0002999999999999999737189393389513725196593441069126129150390625.将其乘以100000的结果的最接近的可表示数字是29.999999999999996447286321199499070644378662109375.

有许多操作,例如floor和mod,可以使非常低的显着性差异非常明显.您需要小心使用它们与浮点数相关联 – 请记住,在许多情况下,您对无限精度值有非常非常接近的近似,而不是无限精度值本身.实际值可能略高,或者在这种情况下略低.

标签:python,c-2,floating-point,floating-accuracy,modulus
来源: https://codeday.me/bug/20190713/1454091.html