欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

python埃氏篩法filter()方法python2運行卡死

系統 1678 0

目的:使用埃氏篩法構造素數

計算素數的一個方法是埃氏篩法,它的算法理解起來非常簡單:
首先,列出從2開始的所有自然數,構造一個序列:
2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, …
取序列的第一個數2,它一定是素數,然后用2把序列的2的倍數篩掉:
3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, …
取新序列的第一個數3,它一定是素數,然后用3把序列的3的倍數篩掉:
5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, …
取新序列的第一個數5,然后用5把序列的5的倍數篩掉:
7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, …
不斷篩下去,就可以得到所有的素數。

代碼實現

            
              #_*_coding:utf_8_*_
def iters():#先構造一個從3開始的奇數序列。這是一個生成器,并且是一個無限序列
    n=1
    while 1:
        n=n+2
        yield n
def isinit(n):#篩選函數
    return lambda x:x%n>0
def prime():
    yield 2
    it=iters()# 初始序列
    while 1:
        n=next(it)# 返回序列的第一個數
        yield n
        it=filter(isinit(n),it)# 構造新序列
for n in prime():
    if(n<10):
        print(n)
    else:
        break

            
          

問題

在python3中能夠直接運行,完美出結果,但是在python2中只出現第一個結果,后面就卡死了。原因是什么呢?搜了好多資料沒有這個的說明,在大神那里得到了答案。

filter() 函數:python2 會把你的 it 遍歷完再直接返回一個 list。python3 不需要遍歷完,它返回一個iterable

解決方法:

自己實現filter方法,重寫里面的邏輯,如下:

            
              def filter(func, it):
    while 1:
        v = next(it)
        if func(v):
            yield v

            
          

至此,上面代碼在python2中也可以完美運行了。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久精品免费视频观看 | 色汉综合 | 国产va免费精品观看精品 | 久久99精品久久久久久综合 | 欧美高清hd| 国产日韩亚洲不卡高清在线观看 | 夜夜草| 中文字幕一区在线观看视频 | 午夜精品一区二区三区在线视 | aaa在线 | 中文字幕一区在线观看视频 | 这里只有精品999 | 国99久9在线 | 免费 | 成人免费观看在线网址 | 91精品国产综合久久久久 | 天天色色色 | 色偷偷噜噜噜亚洲男人 | 欧美日韩一区二区三 | 亚洲毛片网站 | 欧美在线一二三区 | 一级毛片视频在线 | 亚洲国产中文字幕 | 91高清免费观看 | 亚洲成人一区二区三区 | 欧美第一视频 | 欧美国产激情二区三区 | 黄色网址在线播放 | 久久草视频这里只精品 | 99自拍视频在线观看 | 秋霞影院精品久久久久 | 亚洲最大在线 | 天天射夜夜骑 | a级欧美片免费观看 | AV国産精品毛片一区二区三区 | a色在线| 亚洲免费在线视频 | 国产日韩精品一区 | 亚洲精品天堂 | 亚洲精品久久久久久一区二区 | 婷婷天天 | 4hu网站|