成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一篇文章帶你了解Python遞歸函數(shù)

開發(fā) 后端
本文基于Python基礎(chǔ)。Python標準的解釋器沒有針對尾遞歸做優(yōu)化,任何遞歸函數(shù)都存在棧溢出。介紹了在使用遞歸函數(shù)的優(yōu)缺點,優(yōu)點是邏輯簡單清晰,缺點是過深的調(diào)用會導(dǎo)致棧溢出。

[[389295]]

一、什么是遞歸函數(shù)?

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

二、函數(shù)的遞歸調(diào)用原理

實際上遞歸函數(shù)是在棧內(nèi)存上遞歸執(zhí)行的,每次遞歸執(zhí)行一次就會耗費一些棧內(nèi)存。

棧內(nèi)存的大小是限制遞歸深度的重要因素

三、案例分析

1.求階乘

計算階乘n! = 1 x 2 x 3 x … x n,

可以用函數(shù)fact(n)表示。

  1. fact(n) = n! = 1 x 2 x 3 x … x (n-1) x n = (n-1)! x n = fact(n-1) x n 

fact(n)可以表示為n x fact(n-1),只有n=1時需要特殊處理。

于是,fact(n)用遞歸的方式寫出來就是:

  1. def fact(n): 
  2.     if n == 1: 
  3.         return 1 
  4.     return n * fact(n - 1) 

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

  1. def fac(n): 
  2.     if n==1: 
  3.         return 1 
  4.     else
  5.         res=n*fac(n-1) 
  6.         return  res 
  7.  
  8. print(fac(6)) 

運行結(jié)果:

2.斐波拉契級數(shù)

有這樣一個數(shù)列:1,1,2,3,5,8,13,21,34…。其第一元素和第二個元素等于 1,其他元素等于其前面兩個元素的和。

例:

  1. def fab(n):  # 定義斐波拉契級數(shù) 
  2.     if n in [1, 2]:  # 如果n=1或者2 
  3.       return 1 
  4.     return fab(n - 1) + fab(n - 2)  # n>2 
  5.  
  6.  
  7. print(fab(1))  # 斐波拉契級數(shù)的第一個元素 
  8.  
  9. print(fab(2))  # 斐波拉契級數(shù)的第二個元素 
  10.  
  11. print(fab(8))  # 斐波拉契級數(shù)的第8個元素 
  12. print(fab(13))  # 斐波拉契級數(shù)的第9個元素    

運行結(jié)果:

3.遞歸函數(shù)的優(yōu)點

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

遞歸需要注意遞歸的深度。由于遞歸會產(chǎn)生多次函數(shù)調(diào)用,而函數(shù)調(diào)用會消耗代碼的??臻g,如果遞歸的深度太大,會導(dǎo)致棧溢出。以上面的階乘為例,如果計算 100000 的階乘,在一般機器上都會出現(xiàn)棧溢出的問題。

  1. print(fac(10000)) 

如下所示:

四、總結(jié)

本文基于Python基礎(chǔ)。Python標準的解釋器沒有針對尾遞歸做優(yōu)化,任何遞歸函數(shù)都存在棧溢出。介紹了在使用遞歸函數(shù)的優(yōu)缺點,優(yōu)點是邏輯簡單清晰,缺點是過深的調(diào)用會導(dǎo)致棧溢出。

在實際案例中,針對尾遞歸優(yōu)化的語言可以通過尾遞歸防止棧溢出。尾遞歸事實上和循環(huán)是等價的,沒有循環(huán)語句的編程語言只能通過尾遞歸實現(xiàn)循環(huán),進行詳細的講解。

使用Python語言,希望能夠幫助你更好的學習。

 

責任編輯:姜華 來源: Go語言進階學習
相關(guān)推薦

2021-04-24 10:19:41

Python函數(shù)指向

2025-02-19 10:39:26

Python高階函數(shù)函數(shù)名

2021-01-29 18:41:16

JavaScript函數(shù)語法

2023-06-15 10:11:08

JavaScript函數(shù)表達式

2023-05-12 08:19:12

Netty程序框架

2021-06-30 00:20:12

Hangfire.NET平臺

2021-05-21 09:01:29

JavaScript 前端函數(shù)閉包

2023-09-06 14:57:46

JavaScript編程語言

2020-12-08 08:09:49

SVG圖標Web

2021-05-18 08:30:42

JavaScript 前端JavaScript時

2021-06-24 09:05:08

JavaScript日期前端

2021-09-27 09:18:30

ListIterato接口方法

2021-01-26 23:46:32

JavaScript數(shù)據(jù)結(jié)構(gòu)前端

2021-03-05 18:04:15

JavaScript循環(huán)代碼

2021-03-09 14:04:01

JavaScriptCookie數(shù)據(jù)

2024-04-19 14:23:52

SwitchJavaScript開發(fā)

2023-07-30 15:18:54

JavaScript屬性

2021-02-26 20:01:57

SVG濾鏡元素

2023-05-08 08:21:15

JavaNIO編程

2024-01-30 13:47:45

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产精彩视频 | 91最新入口 | 1204国产成人精品视频 | 亚洲永久字幕 | 成人欧美一区二区三区在线播放 | 天天综合久久 | 日韩av福利在线观看 | 欧美福利影院 | 久久免费视频观看 | 国产福利视频网站 | 色婷婷亚洲国产女人的天堂 | 在线亚洲人成电影网站色www | 国外激情av| 精品日韩一区二区 | 在线观看视频一区二区三区 | 国产区高清 | 国产福利视频导航 | 四虎成人在线播放 | av不卡一区 | 精品亚洲一区二区三区 | 国产高清久久 | 国产精品久久久久久一区二区三区 | 亚洲女人天堂成人av在线 | 日韩中文字幕视频 | 国产激情片在线观看 | 荷兰欧美一级毛片 | 日韩国产免费观看 | 91成人在线视频 | 午夜私人影院在线观看 | 日本三级精品 | 日韩欧美一区二区三区四区 | 国产农村妇女毛片精品久久麻豆 | 久久不卡日韩美女 | 91免费视频观看 | 一区二区三区在线播放 | 亚洲美女视频 | 欧美小视频在线观看 | 欧美激情在线精品一区二区三区 | 国产一区二区三区色淫影院 | 免费毛片网站在线观看 | 国产一区欧美 |