91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Python中利用循環機制代替遞歸函數

發布時間:2021-03-24 16:22:41 來源:億速云 閱讀:240 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關怎么在Python中利用循環機制代替遞歸函數,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

斐波那契數列

當年,典型的遞歸題目,斐波那契數列還記得嗎?

def fib(n):
  if n==1 or n==2:
    return 1
  else:
    return fib(n-1)+fib(n-2)

當然, 為了程序健壯性,加上 try...except...

def fib(n):
  if isinstance(n, int):
    print('兄弟,輸入正整數哈')
    return
  try:
    if n==1 or n==2:
      return 1
    elif n <= 0:
      print('兄弟別輸入0或負數呀')
    else:
      return fib(n-1)+fib(n-2)
  except RecursionError:
    print('兄弟,超過了最大遞歸深度'

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

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

我稍微解釋三點:

  • 為啥是 range(2, n) ,因為,斐波那契數列從 1 開始,所以 fib(n) 就是數列的第 n 項 

  • 由于前兩項都為 1 ,所以要少兩項,為 range(2, n) (要循環 n-2 次)

  • a, b = b, a+b 這里你也許也有困惑,我簡單說說,一般Python解釋器會將逗號分隔的變量直接看做一個元組, 

  • 又因為,解釋器先執行等式右邊的,所以,這樣相當于 元組拆包

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

楊輝三角

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

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)

看完上述內容,你們對怎么在Python中利用循環機制代替遞歸函數有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宣城市| 深泽县| 天台县| 姜堰市| 南宁市| 涿鹿县| 鞍山市| 阿巴嘎旗| 图们市| 防城港市| 黄石市| 西丰县| 子长县| 青神县| 明光市| 习水县| 洪泽县| 绵阳市| 车险| 灌阳县| 安国市| 九寨沟县| 崇文区| 土默特左旗| 社会| 颍上县| 扬州市| 新建县| 天台县| 二连浩特市| 望江县| 东港市| 育儿| 威信县| 武隆县| 麻栗坡县| 岳池县| 蒙阴县| 定西市| 弥勒县| 顺义区|