我很好奇为什么乘以比在python中取幂要快得多(尽管据我所读,这在许多其他语言中也可能是正确的)。例如,这样做快得多
x*x
比
x**2
我认为**运算符比较笼统,也可以处理小数幂。但是,如果这就是为什么它这么慢,为什么不执行int指数检查,然后执行乘法运算呢?
编辑:这是我尝试过的一些示例代码...
def pow1(r, n):
for i in range(r):
p = i**n
def pow2(r, n):
for i in range(r):
p = 1
for j in range(n):
p *= i
现在,pow2只是一个简单的例子,显然没有进行优化!
但是即使如此,我仍然发现使用n = 2且r = 1,000,000时,pow1约需2500ms,pow2需约1700ms。
我承认,对于较大的n值,pow1的确比pow2快得多。但这并不奇怪。
沧海一幻觉
回首忆惘然