Python 高階函數 -- filter

来源:https://www.cnblogs.com/ChrisK/archive/2018/08/12/9461990.html
-Advertisement-
Play Games

詳細內容請參考廖雪峰官網,此處只是一些摘抄,心得與練習的coding。 Python內建的filter()函數用於過濾序列。 和map()類似(可參考 Python 高階函數 -- map/reduce),filter()也接收一個函數和一個序列。和map()不同的是,filter()把傳入的函數依 ...


詳細內容請參考廖雪峰官網,此處只是一些摘抄,心得與練習的coding。

  1. Python內建的filter()函數用於過濾序列。

    map()類似(可參考 Python 高階函數 -- map/reduce),filter()也接收一個函數和一個序列。和map()不同的是,filter()把傳入的函數依次作用於每個元素,然後根據返回值是True還是False決定保留還是丟棄該元素。

    例如,在一個list中,刪掉偶數,只保留奇數,可以這麼寫:

    def is_odd(n):
        return n % 2 == 1
    
    list(filter(is_odd, [1, 2, 4, 5, 6, 9, 10, 15]))
    # 結果: [1, 5, 9, 15]

     

  2. 用filter求素數

    計算素數的一個方法是埃氏篩法,它的演算法理解起來非常簡單:

    首先,列出從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, ...

    不斷篩下去,就可以得到所有的素數。

    用Python來實現這個演算法,可以先構造一個從3開始的奇數序列:

    def _odd_iter():
        n = 1
        while True:
            n = n + 2
            yield n

    註意這是一個生成器,並且是一個無限序列。(關於生成器,請參考廖雪峰的另一篇文章)

    然後定義一個篩選函數:

    def _not_divisible(n):
        return lambda x: x % n > 0

    最後,定義一個生成器,不斷返回下一個素數:

    def primes():
        yield 2
        it = _odd_iter() # 初始序列
        while True:
            n = next(it) # 返回序列的第一個數
            yield n
            it = filter(_not_divisible(n), it) # 構造新序列

    這個生成器先返回第一個素數2,然後,利用filter()不斷產生篩選後的新的序列。

    由於primes()也是一個無限序列,所以調用時需要設置一個退出迴圈的條件:

    # 列印1000以內的素數:
    for n in primes():
        if n < 1000:
            print(n)
        else:
            break

    註意到Iterator是惰性計算的序列,所以我們可以用Python表示“全體自然數”,“全體素數”這樣的序列,而代碼非常簡潔。

  3. 練習
    回數是指從左向右讀和從右向左讀都是一樣的數,例如12321909。請利用filter()篩選出回數:
    # -*- coding: utf-8 -*-
    def is_palindrome(n):
        s = str(n)
        count = 0
        length = len(s)
        half = int(length/2) #eg. 1234321 ->half num:3
        flag = True
        while count< half:
            if s[count] == s[length-count-1] :
                count +=1
                continue
            else:
                flag=False
                break
        return flag
    
    
    # 測試:
    output = filter(is_palindrome, range(1, 1000))
    print('1~1000:', list(output))
    if list(filter(is_palindrome, range(1, 200))) == [1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 22, 33,
                                                      44, 55, 66, 77, 88, 99, 101, 111, 121,
                                                      131, 141, 151, 161, 171, 181, 191]:
        print('測試成功!')
    else:
        print('測試失敗!')

     


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 遞歸演算法: 優點:代碼簡潔、清晰,並且容易驗證正確性。 缺點: 1、它的運行需要較多次數的函數調用,如果調用層數比較深,每次都要創建新的變數,需要增加額外的堆棧處理,會對執行效率有一定影響,占用過多的記憶體資源。 2、遞歸演算法解題的運行效率較低。在遞歸調用的過程中系統為每一層的返回點、局部變數等開闢了 ...
  • 1、DOM0級事件和DOM2級事件 DOM 0級事件是元素內的一個私有屬性:div.onclick = function () {},對一個私有屬性賦值(在該事件上綁定一個方法)。由此可知DOM 0級事件只能給元素的某一個行為綁定一次方法,第二次綁定會把前面的覆蓋掉。 DOM 2級事件是讓DOM元素 ...
  • 一.Yeoman是什麼 是現代化前端項目的腳手架工具,用於生成包含指定框架結構的工程化目錄結構。它是整個前端自動化工廠的第一站。 從個人使用者的角度來看, 的地位有些雞肋,因為流行框架自帶的 工具都能夠自動生成官方推薦的目錄結構,而且一個項目持續少則幾個月多則幾年,而項目的初始化結構目錄在此期間只需 ...
  • CSS選擇器總結: (這些表是一張圖片^_^) 看底部 完整思維導圖圖片和表格的下載地址:https://download.csdn.net/download/denlnyyr/10597820 (我不想選擇要積分幣下載的,但那裡最低必須選擇1個積分……) 參考文獻: https://baike.b ...
  • 看到一個知識點,比如說給一個 url參數,讓其解析裡面的各個參數,以前我都是通過字元串分割來實現的。但是通過這樣的方式比較麻煩,而且操作字元串容易出錯。今天看到了一個更有效更快速的方式,就是通過對象來解析的。 比如我們的url是:https://www.baidu.com:8080/aaa/1.ht ...
  • 先附一張官網上的vue實例的生命周期圖,每個Vue實例在被創建的時候都需要經過一系列的初始化過程,例如需要設置數據監聽,編譯模板,將實例掛載到DOM併在數據變化時更新DOM等。同時在這個過程中也會運行一些叫做生命周期鉤子的函數(回調函數),這給了用戶在不同階段添加自己代碼的機會。 1、vue的生命周 ...
  • 為什麼要動態載入呢?而不是一次性載入呢? 一次性?你能保證你拿的內容不多,那從性能方面說還是OK的。否則,就該什麼時候用,就什麼時候取。 得出這想法,源於前幾天上班趕產品的故事: A組件是父親,B組件是A組件的孩子。剛剛,我在A組件里直接載入B組件。 編譯居然用了將近一分半鐘,我都還沒加其他C孩子, ...
  • 1、關於享元模式 享元模式有點類似於單例模式,都是只生成一個對象被共用使用。享元模式主要目的就是讓多個對象實現共用,減少不會要額記憶體消耗,將多個對同一對象的訪問集中起來,不必為每個訪問者創建一個單獨的對象,以此來降低記憶體的消耗。 2、享元模式結構圖 因為享元模式結構比較複雜,一般結合工廠模式一起使用 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...