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

python利用高階函數實現剪枝函數

 更新時間:2018年03月20日 10:28:31   作者:北門吹雪  
這篇文章主要為大家詳細介紹了python利用高階函數實現剪枝函數的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文為大家分享了python利用高階函數實現剪枝函數的具體代碼,供大家參考,具體內容如下

案例:

       某些時候,我們想要為多個函數,添加某種功能,比如計時統(tǒng)計,記錄日志,緩存運算結果等等

       需求:

              在每個函數中不需要添加完全相同的代碼

如何解決?

       把相同的代碼抽調出來,定義成裝飾器

              求斐波那契數列(黃金分割數列),從數列的第3項開始,每一項都等于前兩項之和

         求一個共有10個臺階的樓梯,從下走到上面,一次只能邁出1~3個臺階,并且不能后退,有多少中方法?

       上臺階問題邏輯整理:

              每次邁出都是 1~3 個臺階,剩下就是 7~9 個臺階

                     如果邁出1個臺階,需要求出后面9個臺階的走法

                     如果邁出2個臺階,需要求出后面8個臺階的走法

                     如果邁出3個臺階,需要求出后面7個臺階的走法

              此3種方式走法,通過遞歸方式實現,遞歸像樹,每次遞歸都生成子節(jié)點函數

以上兩個問題通過遞歸來解決,就會出現一個問題,出現重復求解問題,把重復求解的過程剔除掉,在c++語言中稱為剪枝函數

#!/usr/bin/python3
 
 
def jian_zhi(func):
  # 中間字典,判斷已經是否求解過
  median = {}
   
  def wrap(*args):
    # 假如不在中間字典中,說明沒有求解過,添加到字典中去,在的話,直接返回
    if args not in median:
      median[args] = func(*args)
    return median[args]
  return wrap
 
@jian_zhi
def fibonacci(n):
  if n <= 1:
    return 1
  return fibonacci(n-1) + fibonacci(n-2)
 
@jian_zhi
def climb(n, steps):
  count = 0
  # 當最后臺階為0的時候,說明最后只是走了一次
  if n == 0:
    count = 1
  # 當最后臺階不為0的時候,說明還需要走至少一次
  elif n > 0:
    # 對三種情況進行分別處理momo
    for step in steps:
      count += climb(n-step, steps)
       
  # 返回每次遞歸的計數
  return count
 
if __name__ == '__main__':
  print(climb(10, (1, 2, 3)))
  print(fibonacci(20))

  所謂的剪枝函數不過是保證每次遞歸的函數唯一性,利用中間字典保存已經執(zhí)行過得函數和參數,通過判斷參數,剔除重復的函數調用

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 教你使用pyqt實現桌面歌詞功能

    教你使用pyqt實現桌面歌詞功能

    最近無事看到了電腦桌面又想到了最近入門的pyqt5,所以下面這篇文章主要給大家介紹了關于如何使用pyqt實現桌面歌詞功能的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • Python機器學習NLP自然語言處理基本操作關鍵詞

    Python機器學習NLP自然語言處理基本操作關鍵詞

    本文是Python機器學習NLP自然語言處理系列文章,帶大家開啟一段學習自然語言處理 (NLP) 的旅程. 本文主要學習NLP自然語言處理關鍵詞的操作
    2021-09-09
  • 利用Django框架中select_related和prefetch_related函數對數據庫查詢優(yōu)化

    利用Django框架中select_related和prefetch_related函數對數據庫查詢優(yōu)化

    這篇文章主要介紹了利用Python的Django框架中select_related和prefetch_related函數對數據庫查詢的優(yōu)化的一個實踐例子,展示如何在實際中利用這兩個函數減少對數據庫的查詢次數,需要的朋友可以參考下
    2015-04-04
  • Python3 中把txt數據文件讀入到矩陣中的方法

    Python3 中把txt數據文件讀入到矩陣中的方法

    下面小編就為大家分享一篇Python3 中把txt數據文件讀入到矩陣中的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • 使用python爬取微博數據打造一顆“心”

    使用python爬取微博數據打造一顆“心”

    這篇文章主要介紹了使用python基于微博數據打造一顆“心”,作為程序員,我準備了一份特別的禮物,用以往發(fā)的微博數據打造一顆“愛心”,我想她一定會感動得哭了吧,需要的朋友可以參考下
    2019-06-06
  • python腳本設置系統(tǒng)時間的兩種方法

    python腳本設置系統(tǒng)時間的兩種方法

    這篇文章主要介紹了python腳本設置系統(tǒng)時間的兩種方法,其一是調用socket直接發(fā)送udp包到國家授時中心,其二是調用ntplib包,感興趣的小伙伴們可以參考一下
    2016-02-02
  • Python?OpenCV超詳細講解透視變換的實現

    Python?OpenCV超詳細講解透視變換的實現

    OpenCV用C++語言編寫,它具有C?++,Python,Java和MATLAB接口,并支持Windows,Linux,Android和Mac?OS,OpenCV主要傾向于實時視覺應用,并在可用時利用MMX和SSE指令,本篇文章帶你通過OpenCV實現透視變換
    2022-04-04
  • 詳解如何利用Python代碼刪除Word文檔空白行

    詳解如何利用Python代碼刪除Word文檔空白行

    Word文檔內容的整潔性與易讀性是體現文檔水平的關鍵因素之一,許多錯誤或不合理的內容,如多余的空白行,Python為批量刪除Word文檔空白行以及對這一過程的自動化處理提供了強有力的支持,本文將介紹如何利用Python自動化刪除Word文檔中的空白行,需要的朋友可以參考下
    2024-05-05
  • 我用Python抓取了7000 多本電子書案例詳解

    我用Python抓取了7000 多本電子書案例詳解

    這篇文章主要介紹了我用Python抓取了7000 多本電子書案例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • Python os庫常用操作代碼匯總

    Python os庫常用操作代碼匯總

    這篇文章主要介紹了Python os庫常用操作代碼匯總,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11

最新評論