欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Python中素?cái)?shù)的玩法

質(zhì)數(shù)

創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括伊金霍洛網(wǎng)站建設(shè)、伊金霍洛網(wǎng)站制作、伊金霍洛網(wǎng)頁制作以及伊金霍洛網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,伊金霍洛網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到伊金霍洛省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

質(zhì)數(shù)又稱素?cái)?shù)。指整數(shù)在一個(gè)大于1的自然數(shù)中,除了1和此整數(shù)自身外,沒法被其他自然數(shù)整除的數(shù)。換句話說,只有兩個(gè)正因數(shù)(1和自己)的自然數(shù)即為素?cái)?shù)。比1大但不是素?cái)?shù)的數(shù)稱為合數(shù)。1和0既非素?cái)?shù)也非合數(shù)。素?cái)?shù)在數(shù)論中有著很重要的作用。
質(zhì)數(shù)的分布規(guī)律是以36N(N+1)為單位,隨著N的增大,素?cái)?shù)的個(gè)數(shù)以波浪形式漸漸增多。
孿生質(zhì)數(shù)也有相同的分布規(guī)律。

素?cái)?shù),普遍認(rèn)為的分布規(guī)律是沒有規(guī)律。時(shí)而連續(xù)出現(xiàn),時(shí)而又相隔很遠(yuǎn)很遠(yuǎn)。有遠(yuǎn)親、有近鄰,地球?qū)γ嬉策€有幾個(gè)好朋友。
素?cái)?shù),真的就沒有規(guī)律嗎?
合數(shù)可以用公式來表示,而素?cái)?shù)且不能用公式來表示。這就是素?cái)?shù)。
不過這里其實(shí)就蘊(yùn)含著秘密。
既然合數(shù)能用公式表示,間接的也就說明了,素?cái)?shù)必須服從這些公式的限制。而研究合數(shù),其實(shí)也是研究素?cái)?shù)。
有2個(gè)根深蒂固的觀念:
1、素?cái)?shù)的個(gè)數(shù)總是按照自然數(shù)增加10倍來統(tǒng)計(jì)展現(xiàn)的。因?yàn)檫@里一直沿用π(x)與x/lnx的統(tǒng)計(jì)方法。
2、100以內(nèi)有25個(gè)素?cái)?shù),1000以內(nèi)有168個(gè)素?cái)?shù)。就產(chǎn)生了一種根深蒂固的觀念:素?cái)?shù)越來越稀疏。
當(dāng)然這些都沒有錯(cuò)誤,否則也不會(huì)一直陪伴著素?cái)?shù)研究到現(xiàn)在,但它禁錮了人們的思想。有一些數(shù)據(jù)似乎與之相悖。
列舉一些四胞胎素?cái)?shù)的例子,
四胞胎素?cái)?shù)是很少的,在自然數(shù)1000億以內(nèi)僅僅有1209317組。平均間距為82691。兩組之間相距是很遠(yuǎn)的。但總有一些間距僅僅為30的兩對(duì)四胞胎素?cái)?shù)稀稀拉拉的出現(xiàn)。在1000億以內(nèi)共有這樣四胞胎素?cái)?shù)267對(duì),他們是如何分布的呢?
200億以內(nèi)有90個(gè);200-400億之間有55個(gè);
剩下的如何分布的呢,你不會(huì)相信的:
400-600億之間有41個(gè);
600-800億之間有41個(gè);
800-1000億之間有40個(gè);
這樣的分布說明了什么?均勻分布?大家肯定不會(huì)相信的,我也不信,那似乎就只能是巧合了。大家一定也會(huì)認(rèn)為是這純屬巧合。素?cái)?shù)嘛,飄忽不定,怎么分布都有可能,但就是沒有規(guī)律。至少大家還沒有發(fā)現(xiàn)其分布規(guī)律。

打印質(zhì)數(shù)

打印100以內(nèi)的質(zhì)數(shù)

count = 0
for i in range(2,101):
    for x in range(2,i):
        if i%x == 0:
            break
    else:
        print(i)
        count += 1
print("\n","Total: ",count,"number")

----
2
3
5
7
11
13
17
19
23
29
31
37
41
43
47
53
59
61
67
71
73
79
83
89
97

 Total:  25 number

這種方法的思路,時(shí)間復(fù)雜度是O(n2),2層循環(huán),雖然會(huì)break,但效率還是很低的

優(yōu)化算法,尋找中點(diǎn)

其實(shí)我們發(fā)現(xiàn)我們求解質(zhì)數(shù)的時(shí)候,根本不需要從2除到N-1,當(dāng)除數(shù)大于商的時(shí)候我們就不用計(jì)算了。
用數(shù)學(xué)的話來說我們只需除到平方根就好了

count = 0
for i in range(2,100000):
    for x in range(2,int(i**0.5)+1):
        if i%x == 0:
            break
    else:
        print(i)
        count += 1
print("\n","Total: ",count,"number")

----
2
3
5
7
11
13
·······
99907
99923
99929
99961
99971
99989
99991

 Total:  9592 number

繼續(xù)優(yōu)化,大于2的偶數(shù)都不是質(zhì)數(shù)

所以對(duì)于偶數(shù)都不用判斷是不是素?cái)?shù),修改步長

count = 1
print(2)
for i in range(3,100000,2):
    for x in range(2,int(i**0.5)+1):
        if i%x == 0:
            break
    else:
        print(i)
        count += 1
print("\n","Total: ",count,"number")

----
2
3
5
7
11
13
·······
99907
99923
99929
99961
99971
99989
99991

 Total:  9592 number

進(jìn)行優(yōu)化,第二層的for循環(huán)

第二層for循環(huán)判斷的是奇數(shù)/range(2,奇數(shù)的開方)
但是2,4,6,8···這種數(shù)肯定不能被奇數(shù)整除,不用考慮,可以不加判斷

count = 1
print(2)
for i in range(3,100000,2):
    for x in range(3,int(i**0.5)+1,2):
        if i%x == 0:
            break
    else:
        print(i)
        count += 1
print("\n","Total: ",count,"number")

----
2
3
5
7
11
13
·······
99907
99923
99929
99961
99971
99989
99991

 Total:  9592 number

計(jì)算以上方法的效率

計(jì)算以上的程序運(yùn)行時(shí)間,取1000000以內(nèi)的質(zhì)數(shù)

方法一

from datetime import datetime
t1 = datetime.now()
count = 0
for i in range(2,1000000):
    for x in range(2,i):
        if i%x == 0:
            break
    else:
        #print(i)
        count += 1
print("\n","Total: ",count,"number")
t2 = datetime.now()
print("Total_Cost:",(t2-t1).total_seconds(),"s")

我喝了一杯咖啡,還沒計(jì)算完...已經(jīng)超過五分鐘了,不等了
然后減少10倍,測(cè)試100000以內(nèi)的數(shù)據(jù)...用了40s

方法二

from datetime import datetime
t1 = datetime.now()
count = 0
for i in range(2,1000000):
    for x in range(2,int(i**0.5)+1):
        if i%x == 0:
            break
    else:
        #print(i)
        count += 1
print("\n","Total: ",count,"number")
t2 = datetime.now()
print("Total_Cost:",(t2-t1).total_seconds(),"s")

----
 Total:  78498 number
Total_Cost: 6.26467 s

用了6.26467s,效率大大提升

方法三

from datetime import datetime
t1 = datetime.now()
count = 1
#print(2)
for i in range(3,1000000,2):
    for x in range(2,int(i**0.5)+1):
        if i%x == 0:
            break
    else:
       # print(i)
        count += 1
print("\n","Total: ",count,"number")

t2 = datetime.now()
print("Total_Cost:",(t2-t1).total_seconds(),"s")

----
Total:  78498 number
Total_Cost: 5.80345 s

用了5.80345s,效率稍微進(jìn)步

方法四

from datetime import datetime
t1 = datetime.now()
count = 1
#print(2)
for i in range(3,1000000,2):
    for x in range(3,int(i**0.5)+1,2):
        if i%x == 0:
            break
    else:
        #print(i)
        count += 1
print("\n","Total: ",count,"number")

t2 = datetime.now()
print("Total_Cost:",(t2-t1).total_seconds(),"s")

----
 Total:  78498 number
Total_Cost: 3.375002 s

用了3.375002s,效率約提高50%

進(jìn)階方法

在上述方法四的基礎(chǔ)上,引入列表

先把第二層循環(huán)用列表替代
from datetime import datetime
t1 = datetime.now()
count = 1
lst = [2]
for i in range(3,1000000,2):
    #for x in range(3,int(i**0.5)+1,2):
    for x in lst:
        if i%x == 0 and x <= i**0.5:
            break
    else:
        lst.append(i)
        count += 1
t2 = datetime.now()
print("Total Number:", count, "Total_Cost:", (t2-t1).total_seconds(),"s")

----
Total Number: 78498   Total_Cost: 234.643142 s

因?yàn)槊看味家猧f判斷兩次結(jié)構(gòu)(a and b),效率會(huì)低,修改下方案

修改if and 結(jié)構(gòu)
from datetime import datetime

t1 = datetime.now()
count = 1
lst = [2]
for i in range(3,1000000,2):
    flag = False
    middle = int(i**0.5)
    for x in lst:
        if i%x == 0:
            break
        if x > middle:
            flag = True
            break
    if flag:
        lst.append(i)
        count += 1
t2 = datetime.now()
print("Total Number:", count, "Total_Cost:", (t2-t1).total_seconds(),"s")

----
Total Number: 78498 Total_Cost: 1.560107 s

可以可以,上面的方法四計(jì)算1000000內(nèi)素?cái)?shù)用時(shí)是3.37s,而現(xiàn)在,只需要1.56s,效率又提高50%以上

還能優(yōu)化嗎?

有一個(gè)數(shù)在做無用功,它就是2,任何素?cái)?shù)都不能整除2

from datetime import datetime

t1 = datetime.now()
count = 2 #[2]
lst = [3]
for i in range(5,1000000,2):
    flag = False
    middle = int(i**0.5)
    for x in lst:
        if i%x == 0:
            break
        if x > middle:
            flag = True
            break
    if flag:
        lst.append(i)
        count += 1
t2 = datetime.now()
print("Total Number:", count, "Total_Cost:", (t2-t1).total_seconds(),"s")

----
Total Number: 78498 Total_Cost: 1.513069 s

略微提升,也有效果

還有嗎?

在求無限質(zhì)數(shù)的時(shí)候,我們不能預(yù)測(cè)有多少結(jié)果
但是對(duì)于求1000000內(nèi)質(zhì)數(shù),我們現(xiàn)在知道了有多少結(jié)果
這樣就可以提前開辟內(nèi)存空間,替代append()

孿生素?cái)?shù)

還有別的方法嗎?當(dāng)然有!孿生素?cái)?shù)了解下

孿生素?cái)?shù)就是指相差2的素?cái)?shù)對(duì),例如3和5,5和7,11和13…。孿生素?cái)?shù)猜想正式由希爾伯特在1900年國際數(shù)學(xué)家大會(huì)的報(bào)告上第8個(gè)問題中提出,可以這樣描述:存在無窮多個(gè)素?cái)?shù)p,使得p + 2是素?cái)?shù)。素?cái)?shù)對(duì)(p, p + 2)稱為孿生素?cái)?shù)。

總結(jié)下來就是一句話:當(dāng)素?cái)?shù)大于3時(shí),素?cái)?shù)都在 6N-1 和 6N+1 左右分布

素?cái)?shù)2357111317192325
步長24242424

由此,在循環(huán)中用一個(gè)可變步長就可以,C語言有可變步長;
然而Python沒有可變步長這一說- -

下面上代碼實(shí)現(xiàn)

from datetime import datetime

t1 = datetime.now()

count = 3 #2,3,5
lst = [3,5]
step = 4
i = 7
while i < 1000000:
    if i%5 != 0:
        middle = int(i**0.5)
        flag = False
        for x in lst:
            if i%x == 0:
                break
            if x > middle:
                flag = True
                break
        if flag:
            lst.append(i)
            count += 1

    i += step
    step = 4 if step == 2 else 2

t2 = datetime.now()
print("Total Number:", count, "Total_Cost:", (t2-t1).total_seconds(),"s")

----
Total Number: 78498 Total_Cost: 1.35155 s

1.513069s —> 1.35155s 還可以哈哈

質(zhì)數(shù)相關(guān)的理論

  • 哥德巴赫猜想:任何大于5的奇數(shù)都是三個(gè)素?cái)?shù)之和
  • 衍生:任何一個(gè)大于2的偶數(shù)都是兩個(gè)素?cái)?shù)之和
  • 伯特蘭猜想:對(duì)于任意正整數(shù)n>1,存在一個(gè)素?cái)?shù)p,使得n<p<2n
  • 孿生素?cái)?shù)猜想:存在無窮多的形如p和p+2的素?cái)?shù)對(duì)
  • n2+1 猜想:存在無窮多個(gè)形如n2+1的素?cái)?shù),其中n是正整數(shù)

量子計(jì)算機(jī),了解一下......密碼學(xué)、區(qū)塊鏈都將被重新定義~

新聞標(biāo)題:Python中素?cái)?shù)的玩法
URL網(wǎng)址:http://aaarwkj.com/article44/iiheee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)域名注冊(cè)、軟件開發(fā)、網(wǎng)站設(shè)計(jì)公司、App開發(fā)、外貿(mào)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計(jì)公司
有码精品视频在线观看| 91亚洲国产成人精品性色| 十八禁无遮挡污污污网站| 国产在线精品成人欧美| 日本在线观看高清区一区二| 日韩三级成人在线视频| 99热这里只有精品中文| 欧美成人精品免费在线| 亚洲成人乱码一区二区| 18禁免费无遮挡免费视频| 九九热这里只有免费视频| 日韩精品中文字幕有码在线 | 欧美日韩一区二区三区666| 中国一区二区三区毛片| 欧美日韩综合精品无人区| av电影国产在线观看| 国产精品一区日韩专区| 日韩欧美一区二区三级| 国产另类极品熟女露脸自拍| 国产综合永久精品日韩鬼片 | 精品嫩模福利一区二区蜜臀| 国产蜜臀视频一区二区三区| 久久国产综合精品电影| avav男人天堂亚洲天堂| 欧美v日韩v亚洲综合国产高清| 亚洲高清无毛一区二区| 欧美偷拍一区二区三区| 精品爆白浆一区二区三区| 黄色午夜福利在线观看| 91麻豆精品国产91久| 国产麻豆剧传媒国产av| 日本久久在线观看视频| 亚洲精品一区国产精品av| 97资源在线公开视频| 精品视频在线观看传媒| 久久综合视频大片视频| 亚洲毛片一区二区在线| 女同av免费观看网站| 亚洲国产成人一区二区精品区 | 日韩人妻一区二区三区蜜桃视频密| 国精品91人妻一区二区|