python求素數: [p for p in range(2, maxNumber) if 0 not in [p%d for d in range(2, int(p**0.5)+1)]]


題目:

輸入一個大於 2 的自然數,輸出小於該數字的所有素數組成的集合。

 

代碼如下:

maxNumber = int(input('請輸入一個大於 2 的自然數:'))

numbers = [p for p in range(2, maxNumber) if 0 not in [p%d for d in range(2, int(p**0.5)+1)]]

print(numbers)

 

對     numbers = [p for p in range(2, maxNumber) if 0 not in [p%d for d in range(2, int(p**0.5)+1)]]  的解釋:

 

將其展開寫,這長句就等效於下面的代碼

 

  

number = []
for p in range(2, maxNumber):
z = True
for d in range(2, int(p**0.5)+1):
if p % d == 0:
z = False
break
if z:
number.append(p)

 

 相信這樣拆開后,你就很容易明白它的意思啦


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM