为什么 numpy.dot() 对大值给出错误答案?

问题描述

a=list(range(10000))
b=list(range(10000))

result=0
for i,j in zip(a,b):
    result+=i*j
print(result)

print()

import numpy as np

numpy_result=np.dot((np.array(a)),(np.array(b)))
print(numpy_result)

Output

333283335000

-1724114088

解决方法

这是一个溢出问题。

333283335000 远大于 2^31,因此您需要在 long long

中进行操作
numpy_result=np.dot(np.array(a,dtype=np.longlong),np.array(b,dtype=np.longlong))

333283335000

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...