Python判斷素?cái)?shù)的3種方法及for-else語(yǔ)句的用法介紹
題目
輸入一個(gè)數(shù),如果是素?cái)?shù)就輸出"Yes",否則輸出"No"
方法一:暴力枚舉法
def is_prime(x): if x==1: return False; for i in range(2,x): if x%i==0: return False return True n=int(input()) if is_prime(n): print("Yes") else: print("No")
自定義函數(shù)is_prime(),首先排除1,然后再對(duì)該數(shù)之前的數(shù)進(jìn)行枚舉,當(dāng)遇到能被當(dāng)前的數(shù)整除時(shí)返回False,若沒(méi)有數(shù)能將其整除意味著這個(gè)數(shù)是素?cái)?shù),返回True。然后對(duì)返回的結(jié)果進(jìn)行判斷從而輸出"Yes"或"No"
當(dāng)然,我們可以省去最后if-else的判斷,直接在函數(shù)is_prime()里來(lái)輸出"Yes"或"No"
def is_prime(x): if x==1: print("No") return for i in range(2,x): if x%i==0: print("No") break else: print("Yes") n=int(input()) is_prime(n)
for-else語(yǔ)句
在上面的代碼中,我采用了for-else語(yǔ)句,這是一個(gè)比較特殊的語(yǔ)句。當(dāng)for循環(huán)正常結(jié)束時(shí),else也會(huì)執(zhí)行,而當(dāng)for循環(huán)未正常結(jié)束,例如使用break提前退出時(shí),則不會(huì)執(zhí)行。使用這個(gè)語(yǔ)句往往可以減少代碼量,避免使用flag。
方法二:內(nèi)置函數(shù)
import sympy n = int(input()) if sympy.isprime(n): print("Yes") else: print("No")
使用python自帶的sympy庫(kù)中的isprime()函數(shù)僅需一行就能判斷素?cái)?shù)
方法三:優(yōu)化了時(shí)間復(fù)雜度
import math def is_prime(n): if n <= 1: return False if n <= 3: return True if n % 2 == 0 or n % 3 == 0: return False for i in range(5, int(math.sqrt(n)) + 1, 6): if n % i == 0 or n % (i + 2) == 0: return False return True
優(yōu)化后的代碼利用了以下觀察:
1.所有的素?cái)?shù)都是6的倍數(shù)加減1(除了2和3)。
2.如果n可以整除2或3,它肯定不是素?cái)?shù)。
3.如果n不是2或3的倍數(shù),并且不能整除6的倍數(shù)加減1的數(shù),那么它也不是素?cái)?shù)。所以可以只在6的倍數(shù)加減1的數(shù)中進(jìn)行枚舉,跳過(guò)其他數(shù)字。這樣可以減少循環(huán)的次數(shù),提高效率。
附:打印素?cái)?shù)
方法一:
1、打印指定范圍內(nèi)的素?cái)?shù)
def sushu3(c): import math m = 2 List = [] while m < c: j = 2 # 只要從2判斷到根號(hào)m,若m不能被其中的任何一個(gè)數(shù)整除,則m為素?cái)?shù) while j <= math.sqrt(m): if m % j == 0: break j = j + 1 if (j > math.sqrt(m)): List.append(m) m = m + 1 print(f"{c}以?xún)?nèi)的素?cái)?shù):{List}") # 調(diào)用方法sushu3方法,打印100以?xún)?nèi)的素?cái)?shù) if __name__ == '__main__': sushu3(100)
方法二:
2、打印指定區(qū)間內(nèi)的素?cái)?shù)
def sushu4(): Min = int(input("請(qǐng)輸入起始值:")) Max = int(input("請(qǐng)輸入終止值:")) List = [] # 循環(huán)遍歷指定區(qū)間內(nèi)的數(shù) for i in range(Min, Max + 1): if i > 1: # 除了1和本身以外的數(shù),如果能被除則break退出 for j in range(2, i): if (i % j) == 0: break # 若不能被1和本身的數(shù)除則追加到List列表 else: List.append(i) print(f"{Min}~{Max}區(qū)間內(nèi)的素?cái)?shù)有:{List}")
總結(jié)
到此這篇關(guān)于Python判斷素?cái)?shù)的3種方法及for-else語(yǔ)句的用法介紹的文章就介紹到這了,更多相關(guān)Python判斷素?cái)?shù)及for-else語(yǔ)句內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python調(diào)用c++ ctype list傳數(shù)組或者返回?cái)?shù)組的方法
今天小編就為大家分享一篇python調(diào)用c++ ctype list傳數(shù)組或者返回?cái)?shù)組的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-02-02Django 導(dǎo)出 Excel 代碼的實(shí)例詳解
本篇文章主要介紹了Django 導(dǎo)出 Excel 代碼的實(shí)例詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08Python利用Xpath選擇器爬取京東網(wǎng)商品信息
這篇文章主要介紹了Python利用Xpath選擇器爬取京東網(wǎng)商品信息,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06Python3解決棋盤(pán)覆蓋問(wèn)題的方法示例
這篇文章主要介紹了Python3解決棋盤(pán)覆蓋問(wèn)題的方法,簡(jiǎn)單描述了棋盤(pán)覆蓋問(wèn)題的概念、原理及Python相關(guān)操作技巧,需要的朋友可以參考下2017-12-12python實(shí)現(xiàn)雙色球隨機(jī)選號(hào)
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)雙色球隨機(jī)選號(hào),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01pandas篩選某列出現(xiàn)編碼錯(cuò)誤的解決方法
今天小編就為大家分享一篇pandas篩選某列出現(xiàn)編碼錯(cuò)誤的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11python使用PyV8執(zhí)行javascript代碼示例分享
這篇文章主要介紹了python使用PyV8執(zhí)行javascript的小示例,大家參考使用吧2013-12-12使用python+poco+夜神模擬器進(jìn)行自動(dòng)化測(cè)試實(shí)例
這篇文章主要介紹了使用python+poco+夜神模擬器進(jìn)行自動(dòng)化測(cè)試實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04