python_函數遞歸

来源:https://www.cnblogs.com/qinxin1/archive/2019/01/22/10306239.html
-Advertisement-
Play Games

函數遞歸 函數遞歸:函數的遞歸調用,即在函數調用的過程中,又直接或間接地調用了函數本身 直接調用 間接調用 ...


函數遞歸

函數遞歸:函數的遞歸調用,即在函數調用的過程中,又直接或間接地調用了函數本身

# import sys
# print(sys.getrecursionlimit())
# sys.setrecursionlimit(10000)
# print(sys.getrecursionlimit())

直接調用

def foo():
    print('from foo')
    foo()

foo()

間接調用

def bar():
    print('from bar')
    foo()


def foo():
    print('from foo')
    bar()


foo()
遞歸分為兩個階段
1、回溯:
註意:一定要在滿足某種條件結束回溯,否則的無限遞歸
2、遞推

總結:
1、遞歸一定要有一個明確地結束條件
2、沒進入下一次遞歸,問題的規模都應該減少
3、在python中沒有尾遞歸優化

# age(5)=age(4)+2
# age)4)=age(3)+2
# age(3)=age(2)+2
# age(2)=age(1)+2
# age(1)=18

# age(n)=age(n-1)+2 # n > 1
# age(n)=18            #n=1
#

# def age(n):
#     if n == 1:
#         return 18
#     return age(n-1)+2 #age(4)+2
#
# age(5)



items=[1,[2,[3,[4,[5,[6,[7,[8,[9,[10,]]]]]]]]]]
def tell(l):
    for item in l:
        if type(item) is not list:
            print(item)
        else:
            tell(item)

tell(items)

 




您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 【問題描述】 輸出1到n之間所有不重覆的排列,即1到n的全排,要求所產生的任一數列不含有重覆的數字. 【代碼展示】 #include<iostream>using namespace std;int a[100],b[100];void quanpai(int index,int n){ //遞歸邊 ...
  • 1、二維數組的定義:當數組中每個元素帶有兩個下標時,稱這樣的數組為二維數組。在邏輯上可以把二維數組看成是一個具有行和列的表格或一個矩陣。 一般形式:類型說明符 數組名[常量表達式1][常量表達式2]; 例:定義a為3*4(3行4列)的數組,b為5*10(5行10列)的數組。 在記憶體中的表達: 例如: ...
  • 在併發編程中,對於共用資源的使用需要確保絕對的安全性。除了利用鎖機制之外,還有一種無鎖的概念。所謂無鎖,就是假定在併發情況下,對於共用資源的訪問沒有衝突,線程可以一直不停的運行,無需阻塞,如果產生衝突,則使用CAS演算法確保全全性。Java在很多併發代碼中都使用了這種演算法。 CAS演算法的核心參數如下: ...
  • 要使用python中的串口,可以下載pywin32-224-cp36-cp36m-win_amd64.whl去安裝或者pip install去安裝。 調試下來,有一點很不爽,讀取read()數據的timeout時間最小單位是秒,這對應很頻繁的讀取使用,很浪費時間。如果不設置這個時間我在有些串口設備上 ...
  • spring boot 2.0 整合 elasticsearch NoNodeAvailableException ...
  • 【問題描述】 已知三個素數的和為 n ,正整數 n 由鍵盤輸入,計算並輸出這三個素數乘積的最大值。 【代碼展示】 # include<iostream>using namespace std;int sushu(int x){ for(int i=2;i<=x/2;i++){ // 如果是合數,返回 ...
  • SG函數先不說,給自己總結下三大博弈。和二進位及黃金分割聯繫密切,數學真奇妙,如果不用考試就更好了。 1.Bash Game:n個物品,最少取1個,最多取m個,先取完者勝。 給對手留下(m+1)的倍數肯定獲勝。若n%(m+1)==0,先手必敗。 51nod裸題:1066 2.Nim Game:n堆物 ...
  • CImage類中GetPixelAddress()函數來設置獲取對應的顏色值是發現Alpha無效。 不管 newBuffer[3] = a; 如何設置 newImage始終無法透明。 這裡要註意的是 newImage.Create(width,height,32); 這裡第三個函數一定要設置為32 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...