1

我可以使用 for 循环找出毕达哥拉斯三元组,如下所示:

def triplet(n): # Find all the Pythagorean triplets between 1 and n (inclusive)
  for a in range(n+1):
    for b in range(a):
      for c in range(b):
        if a*a == b*b + c*c:
          print(a, b, c)

我想用一个使用列表理解的单行替换它并尝试了以下部分:

[a, b, c in range(n+1), range(a), range(b) if a*a == b*b + c*c]

但是,我在右方括号上收到语法错误。我尝试使用简单的括号将列表更改为元组,但没有成功。我可以知道如何正确处理吗?

4

2 回答 2

6

我想你的意思是

[(a,b,c) for a in range(n+1) for b in range(a) for c in range(b) if a*a == b*b + c*c]

这至少在语法上是有效的。

于 2017-09-09T12:03:47.410 回答
1

注意:此解决方案仅适用于以下问题a + b + c <= N

假设a<=b<=c,这个版本要快一点:

triplet = [(a,b,c) for a in range(1,N//3+1) for b in range(a,N//2+1) for c in range(b,N-1) if a**2 + b**2 == c**2]
于 2018-12-13T13:34:56.257 回答