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

Python遞歸及尾遞歸優(yōu)化操作實(shí)例分析

 更新時(shí)間:2020年02月01日 11:57:49   作者:dayL_W  
這篇文章主要介紹了Python遞歸及尾遞歸優(yōu)化操作,結(jié)合實(shí)例形式分析了Python遞歸及尾遞歸優(yōu)化相關(guān)概念、原理、應(yīng)用與操作技巧,需要的朋友可以參考下

本文實(shí)例講述了Python遞歸及尾遞歸優(yōu)化操作。分享給大家供大家參考,具體如下:

1、遞歸介紹

遞歸簡(jiǎn)而言之就是自己調(diào)用自己。使用遞歸解決問(wèn)題的核心就是分析出遞歸的模型,看這個(gè)問(wèn)題能拆分出和自己類似的問(wèn)題并且有一個(gè)遞歸出口。比如最簡(jiǎn)單的就5的階乘,可以把它拆分成5*4!,然后求4!又可以調(diào)用自己,這種問(wèn)題顯然可以用遞歸解決,遞歸的出口就是求1!,可以直接返回1。用Python實(shí)現(xiàn)如下:

def fact(n):
  if n==1:
    return n
  return n*fact(n - 1);
print(fact(5))

運(yùn)行結(jié)果:

120

2、尾遞歸優(yōu)化

在上面的求遞歸中,也有一定的缺點(diǎn),假如說(shuō)求1000!的階乘,會(huì)出現(xiàn)棧溢出的問(wèn)題,因?yàn)樵诤瘮?shù)執(zhí)行中,沒(méi)調(diào)用一個(gè)函數(shù)都會(huì)把當(dāng)前函數(shù)的調(diào)用位置和內(nèi)部變量保存在棧里面,由于棧的空間不是無(wú)限大(具體棧的最大空間還沒(méi)有查找到),假如說(shuō)調(diào)用層數(shù)過(guò)多,就是出現(xiàn)棧溢出的情況。

這個(gè)時(shí)候就可以用尾遞歸優(yōu)化來(lái)解決,尾調(diào)用的概念非常簡(jiǎn)單,一句話就能說(shuō)清楚,就是指某個(gè)函數(shù)的最后一步是調(diào)用另一個(gè)函數(shù)。

function f(x){
 return g(x);
}

尾遞歸優(yōu)化后的階乘函數(shù)如下:

def fact(n):
  return fact_iter(n,1);
def fact_iter(num, product):
  if num == 1:
    return product
  return fact_iter(num - 1, num * product)
print(fact(5))
print(fact(1000))

尾調(diào)用由于是函數(shù)的最后一步操作,所以不需要保留外層函數(shù)的調(diào)用記錄,因?yàn)檎{(diào)用位置、內(nèi)部變量等信息都不會(huì)再用到了。所以尾遞歸優(yōu)化可以有效的防止棧溢出,但是尾遞歸優(yōu)化需要編譯器或者解釋器的支持,遺憾的是,大多數(shù)編程語(yǔ)言沒(méi)有針對(duì)尾遞歸做優(yōu)化,Python解釋器也沒(méi)有做優(yōu)化,所以,即使把上面的fact(n)函數(shù)改成尾遞歸方式,也會(huì)導(dǎo)致棧溢出。

3、漢諾塔問(wèn)題

漢諾塔問(wèn)題也是一個(gè)經(jīng)典的遞歸問(wèn)題,具體題目就不說(shuō)了,這里分析思路。假設(shè)hanoi(n, a, b, c)實(shí)現(xiàn)把a(bǔ)上的n個(gè)盤子移到c上。

當(dāng)只有一個(gè)盤子時(shí),直接從A移動(dòng)到C即可

如果有3個(gè)盤子,可以這樣:

# A --> C
# A --> B
# C --> B
# A --> C
# B --> A
# B --> C
# A --> C

如果有很多盤子,我們分析一下該怎么移動(dòng),首先,我們需要把n-1個(gè)盤子移動(dòng)到b中,才可以實(shí)現(xiàn)最簡(jiǎn)單的一步,把a(bǔ)中最大的盤子移動(dòng)到c中,具體怎么轉(zhuǎn)移到b中后面再討論。移動(dòng)最大的盤子后,a和c都可以看成是空的,接下來(lái),把b看成是a,把a(bǔ)看成是b,把a(bǔ)中的n-1個(gè)盤子(這里的n是已經(jīng)減1的n)移動(dòng)到b后,又可以移動(dòng)第二大的盤子。這顯然是一個(gè)遞歸問(wèn)題。

遞歸的出口就是n等于1,直接從a移動(dòng)到c即可。

那么怎么接下來(lái)討論,怎么把n-1個(gè)盤子移動(dòng)到b,這不又是一個(gè)遞歸問(wèn)題嘛!可以調(diào)用它自己呀,只不過(guò)需要把b看成是c,把c看成是b。所以代碼如下:

def hanoi(n,a,b,c):
  #只有一個(gè)盤子,直接移動(dòng)
  if n==1:
    print(a,'->',c)
  else:
    #通過(guò)c把n-1個(gè)盤子移動(dòng)到b
    hanoi(n-1, a,c,b)
    #移動(dòng)最大的盤子
    print(a,'->',c)
    #通過(guò)a把n-1個(gè)盤子移動(dòng)到c
    hanoi(n-1, b,a,c)
hanoi(3,'A','B','C')

運(yùn)行結(jié)果:

A -> C
A -> B
C -> B
A -> C
B -> A
B -> C
A -> C

轉(zhuǎn)自https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/001431756044276a15558a759ec43de8e30eb0ed169fb11000

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python列表(list)操作技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Python Reduce函數(shù)的高級(jí)用法詳解

    Python Reduce函數(shù)的高級(jí)用法詳解

    這篇文章主要介紹了reduce函數(shù)的工作原理和應(yīng)用,同時(shí)提供豐富的示例代碼,方便更好地理解如何使用reduce函數(shù)來(lái)輕松解決復(fù)雜的數(shù)據(jù)聚合問(wèn)題,需要的可以參考下
    2023-11-11
  • Python基礎(chǔ)之變量基本用法與進(jìn)階詳解

    Python基礎(chǔ)之變量基本用法與進(jìn)階詳解

    這篇文章主要介紹了Python基礎(chǔ)之變量基本用法與進(jìn)階,結(jié)合實(shí)例形式詳細(xì)分析了Python變量引用、可變和不可變類型、局部變量和全局變量等相關(guān)原理與使用技巧,需要的朋友可以參考下
    2020-01-01
  • Python+Socket實(shí)現(xiàn)基于UDP協(xié)議的局域網(wǎng)廣播功能示例

    Python+Socket實(shí)現(xiàn)基于UDP協(xié)議的局域網(wǎng)廣播功能示例

    這篇文章主要介紹了Python+Socket實(shí)現(xiàn)基于UDP協(xié)議的局域網(wǎng)廣播功能,結(jié)合實(shí)例形式分析了Python+socket實(shí)現(xiàn)UDP協(xié)議廣播的客戶端與服務(wù)器端功能相關(guān)操作技巧,需要的朋友可以參考下
    2017-08-08
  • 利用Python操作MongoDB數(shù)據(jù)庫(kù)的詳細(xì)指南

    利用Python操作MongoDB數(shù)據(jù)庫(kù)的詳細(xì)指南

    MongoDB是由C++語(yǔ)言編寫的非關(guān)系型數(shù)據(jù)庫(kù),是一個(gè)基于分布式文件存儲(chǔ)的開(kāi)源數(shù)據(jù)庫(kù)系統(tǒng),其內(nèi)容存儲(chǔ)形式類似JSON對(duì)象,下面這篇文章主要給大家介紹了關(guān)于利用Python操作MongoDB數(shù)據(jù)庫(kù)的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • 使用Python函數(shù)進(jìn)行模塊化的實(shí)現(xiàn)

    使用Python函數(shù)進(jìn)行模塊化的實(shí)現(xiàn)

    這篇文章主要介紹了使用Python函數(shù)進(jìn)行模塊化的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Django url,從一個(gè)頁(yè)面調(diào)到另個(gè)頁(yè)面的方法

    Django url,從一個(gè)頁(yè)面調(diào)到另個(gè)頁(yè)面的方法

    今天小編就為大家分享一篇Django url,從一個(gè)頁(yè)面調(diào)到另個(gè)頁(yè)面的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • 使用python編寫android截屏腳本雙擊運(yùn)行即可

    使用python編寫android截屏腳本雙擊運(yùn)行即可

    使用python編寫一個(gè)截屏的腳本,雙擊運(yùn)行腳本就OK,截屏成功后會(huì)將截屏文件已當(dāng)前時(shí)間命名,并保存在存放腳本的當(dāng)前路徑的screenshot文件夾下
    2014-07-07
  • python類的繼承實(shí)例詳解

    python類的繼承實(shí)例詳解

    這篇文章主要介紹了python類的繼承實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • python Matplotlib數(shù)據(jù)可視化(2):詳解三大容器對(duì)象與常用設(shè)置

    python Matplotlib數(shù)據(jù)可視化(2):詳解三大容器對(duì)象與常用設(shè)置

    這篇文章主要介紹了python Matplotlib三大容器對(duì)象與常用設(shè)置的相關(guān)資料,幫助大家更好的學(xué)習(xí)和使用Matplotlib庫(kù)的用法,感興趣的朋友可以了解下
    2020-09-09
  • python自動(dòng)化工具之pywinauto實(shí)例詳解

    python自動(dòng)化工具之pywinauto實(shí)例詳解

    這篇文章主要為大家詳細(xì)介紹了python自動(dòng)化工具之pywinauto實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08

最新評(píng)論