3

我试图找到 n 的所有值,使得 (2^n-7) 是一个完美的正方形。我的代码是:

import math

def isperfect(n):
      return math.sqrt(n) % 1 == 0


print [i for i in range(3,200) if isperfect(2**(i)-7)]

这是我得到的:

[3, 4, 5, 7, 15, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 78, 80, 82, 84, 86, 88, 90, 92, 94, 96, 98, 100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122, 124, 126, 128, 130, 132, 134, 136, 138, 140, 142, 144, 146, 148, 150, 152, 154, 156, 158, 160, 162, 164, 166, 168, 170, 172, 174, 176, 178, 180, 182, 184, 186, 188, 190, 192, 194, 196, 198]

我知道在 n=15 之前它是正确的,但是在那之后它都是错误的,因为下一个 n 应该是 238。到目前为止我的理解是,问题是由于sqrt(n). 有没有办法解决问题。

4

0 回答 0