欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python判斷素?cái)?shù)的3種方法及for-else語(yǔ)句的用法介紹

 更新時(shí)間:2024年05月03日 11:57:09   作者:Zaly.  
素?cái)?shù)又叫質(zhì)數(shù),指的是>1的整數(shù)中,只能被1和這個(gè)數(shù)本身整除的數(shù),這篇文章主要給大家介紹了關(guān)于Python判斷素?cái)?shù)的3種方法及for-else語(yǔ)句的用法介紹的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

題目

輸入一個(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)文章

最新評(píng)論