亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python遞歸函數(shù)定義與用法示例

 更新時間:2017年06月02日 11:53:40   作者:艾森豪威邇  
這篇文章主要介紹了Python遞歸函數(shù)定義與用法,結(jié)合具體實例形式分析了Python遞歸函數(shù)的原理、實現(xiàn)技巧與相關(guān)注意事項,需要的朋友可以參考下

本文實例講述了Python遞歸函數(shù)定義與用法。分享給大家供大家參考,具體如下:

遞歸函數(shù)

在函數(shù)內(nèi)部,可以調(diào)用其他函數(shù)。如果一個函數(shù)在內(nèi)部調(diào)用自身本身,這個函數(shù)就是遞歸函數(shù)。

舉個例子,我們來計算階乘 n! = 1 * 2 * 3 * ... * n,用函數(shù) fact(n)表示,可以看出:

fact(n) = n! = 1 * 2 * 3 * ... * (n-1) * n = (n-1)! * n = fact(n-1) * n

所以,fact(n)可以表示為 n * fact(n-1),只有n=1時需要特殊處理。
于是,fact(n)用遞歸的方式寫出來就是:

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

上面就是一個遞歸函數(shù)??梢栽囋嚕?/p>

>>> fact(1)
1
>>> fact(5)
120
>>> fact(100)
93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000L

如果我們計算fact(5),可以根據(jù)函數(shù)定義看到計算過程如下:

===> fact(5)
===> 5 * fact(4)
===> 5 * (4 * fact(3))
===> 5 * (4 * (3 * fact(2)))
===> 5 * (4 * (3 * (2 * fact(1))))
===> 5 * (4 * (3 * (2 * 1)))
===> 5 * (4 * (3 * 2))
===> 5 * (4 * 6)
===> 5 * 24
===> 120

遞歸函數(shù)的優(yōu)點是定義簡單,邏輯清晰。理論上,所有的遞歸函數(shù)都可以寫成循環(huán)的方式,但循環(huán)的邏輯不如遞歸清晰。

使用遞歸函數(shù)需要注意防止棧溢出。在計算機中,函數(shù)調(diào)用是通過棧(stack)這種數(shù)據(jù)結(jié)構(gòu)實現(xiàn)的,每當進入一個函數(shù)調(diào)用,棧就會加一層棧幀,每當函數(shù)返回,棧就會減一層棧幀。由于棧的大小不是無限的,所以,遞歸調(diào)用的次數(shù)過多,會導致棧溢出。可以試試計算 fact(10000)。

def digui(n):
  sum = 0
  if n<=0:
    return 1
  else:
    return n*digui(n-1)
print(digui(5))

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

希望本文所述對大家Python程序設計有所幫助。

相關(guān)文章

  • 你應該知道的Python3.6、3.7、3.8新特性小結(jié)

    你應該知道的Python3.6、3.7、3.8新特性小結(jié)

    這篇文章主要介紹了你應該知道的Python3.6、3.7、3.8新特性小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • 簡單了解python反射機制的一些知識

    簡單了解python反射機制的一些知識

    這篇文章主要介紹了簡單了解python反射機制的一些知識,反射機制就是在運行時,動態(tài)的確定對象的類型,并可以通過字符串調(diào)用對象屬性、方法、導入模塊,是一種基于字符串的事件驅(qū)動。,需要的朋友可以參考下
    2019-07-07
  • 編寫Python腳本來實現(xiàn)最簡單的FTP下載的教程

    編寫Python腳本來實現(xiàn)最簡單的FTP下載的教程

    這篇文章主要介紹了編寫Python腳本來實現(xiàn)最簡單的FTP下載的教程,主要用到了ftplib模塊,無圖形界面...需要的朋友可以參考下
    2015-05-05
  • 使用python爬取連續(xù)降水數(shù)據(jù)信息實例

    使用python爬取連續(xù)降水數(shù)據(jù)信息實例

    這篇文章主要為大家介紹了使用python提取連續(xù)降水數(shù)據(jù)信息實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-01-01
  • Python編程實現(xiàn)微信企業(yè)號文本消息推送功能示例

    Python編程實現(xiàn)微信企業(yè)號文本消息推送功能示例

    這篇文章主要介紹了Python編程實現(xiàn)微信企業(yè)號文本消息推送功能,結(jié)合實例形式分析了Python微信企業(yè)號文本消息推送接口的調(diào)用相關(guān)操作技巧,需要的朋友可以參考下
    2017-08-08
  • python 調(diào)用HBase的簡單實例

    python 調(diào)用HBase的簡單實例

    下面小編就為大家?guī)硪黄猵ython 調(diào)用HBase的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • python實現(xiàn)根據(jù)指定字符截取對應的行的內(nèi)容方法

    python實現(xiàn)根據(jù)指定字符截取對應的行的內(nèi)容方法

    今天小編就為大家分享一篇python實現(xiàn)根據(jù)指定字符截取對應的行的內(nèi)容方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • python中IO流和對象序列化詳解

    python中IO流和對象序列化詳解

    大家好,本篇文章主要講的是python中IO流和對象序列化詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • python?list與numpy數(shù)組效率對比

    python?list與numpy數(shù)組效率對比

    這篇文章主要介紹了python?list與numpy數(shù)組效率對比分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Python爬蟲的兩套解析方法和四種爬蟲實現(xiàn)過程

    Python爬蟲的兩套解析方法和四種爬蟲實現(xiàn)過程

    本文想針對某一網(wǎng)頁對 python 基礎爬蟲的兩大解析庫( BeautifulSoup 和 lxml )和幾種信息提取實現(xiàn)方法進行分析,及同一網(wǎng)頁爬蟲的四種實現(xiàn)方式,需要的朋友參考下吧
    2018-07-07

最新評論