日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python 递归函数与循环的区别_提升Python效率之使用循环机制代替递归函数

發(fā)布時(shí)間:2023/12/20 python 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 递归函数与循环的区别_提升Python效率之使用循环机制代替递归函数 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

斐波那契數(shù)列

當(dāng)年,典型的遞歸題目,斐波那契數(shù)列還記得嗎?

def fib(n):

if n==1 or n==2:

return 1

else:

return fib(n-1)+fib(n-2)

當(dāng)然, 為了程序健壯性,加上try...except...

def fib(n):

if isinstance(n, int):

print('兄弟,輸入正整數(shù)哈')

return

try:

if n==1 or n==2:

return 1

elif n <= 0:

print('兄弟別輸入0或負(fù)數(shù)呀')

else:

return fib(n-1)+fib(n-2)

except RecursionError:

print('兄弟,超過了最大遞歸深度'

是的,無論時(shí)間還是空間復(fù)雜度,遞歸真的是不太好使哈!這是遞歸的寫法:

def fib(n):

if n==1 or n == 2:

return 1

a, b = 1, 1

for i in range(2, n):

a, b = b, a+b

return b

我稍微解釋三點(diǎn):

為啥是range(2, n),因?yàn)?#xff0c;斐波那契數(shù)列從?1 開始,所以?fib(n) 就是數(shù)列的第?n 項(xiàng)

由于前兩項(xiàng)都為?1 ,所以要少兩項(xiàng),為?range(2, n)(要循環(huán)?n-2 次)

a, b = b, a+b 這里你也許也有困惑,我簡(jiǎn)單說說,一般Python解釋器會(huì)將逗號(hào)分隔的變量直接看做一個(gè)元組,

又因?yàn)?#xff0c;解釋器先執(zhí)行等式右邊的,所以,這樣相當(dāng)于?元組拆包

a, b = b, a+b 這句話的精髓在于,在等式右邊將?b 視為fib(n-2) ,將?a+b 視為?fib(n-1)

楊輝三角

同樣,先寫遞歸寫法(我這里不考慮特殊情況了,時(shí)間有限):

def YH_tri(a, b):

if a == b or b == 0:

return 1

else:

return YH_tri(a-1, b)+YH_tri(a-1, b-1)

老鐵們自己先想想該怎么寫??

總結(jié)

以上所述是小編給大家介紹的提升Python效率之使用循環(huán)機(jī)制代替遞歸函數(shù),希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)我們網(wǎng)站的支持!

如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

本文標(biāo)題: 提升Python效率之使用循環(huán)機(jī)制代替遞歸函數(shù)

本文地址: http://www.cppcns.com/jiaoben/python/266539.html

總結(jié)

以上是生活随笔為你收集整理的python 递归函数与循环的区别_提升Python效率之使用循环机制代替递归函数的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。