我刚刚开始了python教程。为什么
print int (100*(11.20 - 11))在python中打印19而不是20 ??整数做了一些舍入,但我无法理解。我们很感激你的帮助。
发布于 2015-01-05 20:14:51
之所以会出现这种情况,是因为11.20不是1120/100,但略小于1120/100。因此,11.20 - 11的结尾略小于20/100 (*)。乘以100,11.20 - 11产生一个略低于20的浮点数,并且由于int(...)截断(圆圈向零),结果为19。
出于效率的考虑,浮点数被表示为分数,分母为2的幂。所以1/2,1/4,1/16,…可以精确地表示为浮点数,但1/5不能(没有2的幂可以用作分母来精确表示1/5 )。
(*)这种浮点减法恰巧是精确的,因此结果的绝对误差与20/100的绝对误差完全相同,与1120/100相比,绝对误差为11.20。注意,相对误差被放大了,因为同样的绝对误差被应用到一个小得多的值上。对已经不精确且接近被称为“灾难性取消”的值的减法,以及您的Python中的减法就是这样一种灾难性的取消。
发布于 2015-01-05 20:15:25
11.2 - 11实际产量
0.1999999999999993最后打到19场。
https://stackoverflow.com/questions/27787124
复制相似问题