python - 当我迭代列表并添加它们时,它给了我一个奇怪的总和

标签 python python-3.x list floating-point operation

a= [8, 12, 11, 15, 12, 2, 16, 3, 6, 19]
mean_a = sum(a)/len(a)
b = list(map(lambda x: x-mean_a, a))

tot = 0
for i in b:
    tot+=i
print(tot**2)

#it 给了我这个奇怪的答案:1.262177448353619e-29

最佳答案

我假设你期待 0?如果是这样,这只是floating-point precision error的另一种情况。 ,因为 float 由计算机以 2 为基数的分数进行处理。答案实际上是 0;您可以四舍五入到一定的小数位数来得到这个答案。

sum(a) = 104
len(a) = 10
    
mean_a = 10.4

b = [-2.4000000000000004, 1.5999999999999996, 0.5999999999999996, 4.6, 1.5999999999999996, -8.4, 5.6, -7.4, -4.4, 8.6]

sum(b) = -3.552713678800501e-15

sum(b)**2 = 1.262177448353619e-29

浮点错误出现两次;当您创建 b 以及对其值求和时。

关于python - 当我迭代列表并添加它们时,它给了我一个奇怪的总和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71984020/

相关文章:

python - Pandas groupby - 对用户进行分组并计算订阅类型

python:来自 math 和 os 模块的函数被 EINTR 中断

python - 如何将 numpy 复杂数组转换为两个元素的 float 组?

python - 两个基本的 ANTLR 问题

python-3.x - 从 pandas 数据框中删除\n 的问题

python - 我尝试使用 Python 将列表每次旋转两次

java - 如何禁用按钮并清除数组列表?

javascript - 如何使用regEx删除js中的python注释

ajax - 当浏览器中的值发生变化时,如何刷新 django 管理表单?

python - 在 2048 中创建一个 shift 函数