国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

如何用Python計算100以內的素數?

瀏覽:128日期:2022-06-29 13:41:07

問題描述

#!/usr/bin/python# -*- coding: UTF-8 -*-import math L = range(0,101)def isprime(n): if n<= 1:return False for i in range(2,int(math.sqrt(n)) + 1):if n % i == 0: return Falsereturn True **# 這個return為什么要放到for的下面?為什么不放到 if n % i == 0 下面?**y = filter(isprime, L )print y

問題解答

回答1:

判斷一個數 n 是否為素數:

從 2 到 sqrt(n): 存在一個 n 為因數,不為素數,返回 False不存在,為素數,返回 true

所以,return True是在判斷 2 到 sqrt(n) 中的每一個數都不是因數的情況下,就是素數,返回True.所以是在循環外面,而不是在里面.

回答2:

因為如果在for循環體中, 如果找到一個能夠被整除的數, 那就代表這個n不是素數, 立馬就返回False, 如果for循環體都運行完了, 也沒有找到一個能夠整除的, 這才能代表這個n是素數, 所以return True 需要放到for下面.

另外, 可以參考我一篇博客的思路: Python 打印一定數值內的素數

回答3:

在循環體內return的話遇到第一個n % i != 0的數時就終止循環返回了,無法驗證n是否不能被100以內每個數(除去1和本身)整除,所以return需要在循環體外。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产一区在线播放 | 国产精品久久自在自线观看 | 99久久精品男女性高爱 | 国产亚洲一欧美一区二区三区 | 亚洲欧美在线观看视频 | 步兵精品手机在线观看 | 美女做爰视频在线观看免费 | 国产精品九九 | 成人9久久国产精品品 | 日韩三级一区 | 欧美aaa级 | 日本不卡一二三区 | 国产剧情一区二区 | 日韩免费高清一级毛片 | a级片在线观看免费 | 日韩精品综合 | 国产人做人爱视频精品 | 欧美精品免费线视频观看视频 | 欧美一区二区三区视频 | 亚洲第一免费网站 | 日韩毛片在线免费观看 | 免费成人高清视频 | 久久久久久久亚洲精品一区 | 一级毛片中国 | 韩国精品视频在线观看 | 日本精品中文字幕有码 | 男人和女人搞黄 | 亚洲更新 | 国产成人一区二区三区在线视频 | 六月成人网 | 亚洲欧美另类自拍第一页 | 波多野在线播放 | 男人的天堂网在线 | 韩国欧洲一级毛片免费 | 国产美女三级做爰 | 成人国产精品一区二区网站 | 亚洲精品国产手机 | 国产亚洲欧洲精品 | 欧美操操操 | 日韩毛片高清在线看 | 91精品久久久久久久久网影视 |