Python中遞歸以及遞歸遍歷目錄詳解
遞歸
遞歸的概念:函數(shù)包含了對自身的調(diào)用,那么就是遞歸
使用的場景:如果你發(fā)現(xiàn)你將要做的事情就是你現(xiàn)在做的,那么用遞歸
遞歸類似循環(huán);在編寫或閱讀遞歸時,首先我們關(guān)注的是遞歸的終止條件
遞歸求和
在接觸遞歸之前,我們先來做這么一個問題:如果說,要對一個數(shù)字列表求和(或者其他序列)求和,除了我們可以使用內(nèi)置的sum函數(shù),還有什么辦法?
while循環(huán)
L = [1,2,3,4,5] mysum = 0 #保存和的變量 while L: #將列表最為循環(huán)條件 mysum += L[0] #每次將列表第一個位置的值加到和中 L = L[1:] #去掉列表第一個元素
for循環(huán)
L = [1,2,3,4,5] mysum = 0 for var in L: mysum += var
遞歸求和
def mysum(L): if not L: print ('L is empty') return 0 else: return L[0]+mysum(L[1:]) # 在返回值中,我們返回了一個函數(shù)的調(diào)用,并且傳遞的參數(shù)為去掉當前列表第一個元素的新列表
遞歸處理非線性循環(huán)
遞歸還可以處理一些非線性循環(huán),而普通的循環(huán)是無法處理的;比如這樣一個列表對其求和:
L = [1,[2,[3,4],5],6,[7,8]]
由于這個列表不是一個線性迭代,包含著復雜的元素嵌套,普通的循環(huán)語句處理起來將會非常難以控制
L = [1,[2,[3,4],5],6,[7,8]] sum = 0 def mysum(L): global sum for var in L: if not isinstance(var,list): #如果其中元素不為列表類型,則為一個確定的值 sum += var else: mysum(var) return
花錢遞歸
思考:假如你有10000塊,每天花一半,毛錢直接舍棄,那么這錢可以花幾天?
遞歸解決:
def cost(money,day=0): if money > 0: money = money // 2 #每次花一半 day += 1 #花完天數(shù)+1 cost(money,day) #開啟花錢遞歸 else: print('一共可以花%d天' % day) return #必須要有的一個終止條件
遞歸注意事項
Python中,遞歸的最大上限次數(shù)差不多是998次,一個沒有終止條件的遞歸會引發(fā)錯誤(類似一個死循環(huán))
這是因為遞歸的每一次函數(shù)執(zhí)行,都會在內(nèi)存中產(chǎn)生新的函數(shù)副本,遞歸的內(nèi)存消耗要大于普通循環(huán)
>>> def func(): ... return func() ... >>> func() Traceback (most recent call last): File "<stdin>", line 1, in <module> File "<stdin>", line 2, in func File "<stdin>", line 2, in func File "<stdin>", line 2, in func [Previous line repeated 995 more times] RecursionError: maximum recursion depth exceeded #這里我們在995次遞歸之后,達到上線,從而報錯
我們也可以手動干預遞歸的上限,但是這是有風險的,要結(jié)合計算機本身內(nèi)存來考慮
>>> import sys >>> sys.setrecursionlimit(num) # num為控制修改的最大遞歸上限次數(shù)
實現(xiàn)Tree命令
核心思路在于,目錄結(jié)構(gòu)的深度及廣度是錯綜復雜的,通過單純的循環(huán)來做判定是一件非常苦難的事情
而遞歸恰好適合這樣的非線性循環(huán)問題,當然也有一些弊端,當目錄結(jié)構(gòu)越來越復雜,那么程序的執(zhí)行效率會越來越差
import os def getdir(path, level=0): if path == '': path = os.getcwd() # 獲取當前的工作目錄 level += 4 num = level // 4 abs_path = os.path.abspath(path) for name in os.listdir(path): # 返回的是一個列表 format_str = '' if os.path.isfile(os.path.join(abs_path, name)): for var in range(num): # range函數(shù)用來控制循環(huán)次數(shù) format_str += '_' * 4 + '▕' format_str = format_str[0:-1] format_str += name mystr = format_str.replace('_', ' ', level-4) # 替換掉level-4個_ else: for var in range(num): # range函數(shù)用來控制循環(huán)次數(shù) format_str += '_' * 4 + '▕' # 輸出樣式構(gòu)造 format_str += name mystr = format_str.replace('_',' ',level-4) # 替換掉level-4個_ print(mystr) # 輸出格式字符串 name = os.path.join(abs_path,name) if os.path.isdir(name): # 絕對路徑,判斷是否是文件夾 getdir(name,level) path = input('請輸入你要遍歷的目錄:') getdir(path)
總結(jié)
到此這篇關(guān)于Python中遞歸以及遞歸遍歷目錄的文章就介紹到這了,更多相關(guān)Python遞歸遍歷目錄內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Python將PDF文件轉(zhuǎn)存為圖片的代碼示例
因工作中的某些奇葩要求,需要將PDF文件的每頁內(nèi)容轉(zhuǎn)存成按順序編號的圖片,用第三方軟件或者在線轉(zhuǎn)換也可以,但批量操作還是Python方便,所以本文給大家介紹了使用Python將PDF文件轉(zhuǎn)存為圖片的方法,需要的朋友可以參考下2023-09-09Pytorch從0實現(xiàn)Transformer的實踐
本文主要介紹了Pytorch從0實現(xiàn)Transformer的實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-05-05Python 模擬員工信息數(shù)據(jù)庫操作的實例
下面小編就為大家?guī)硪黄狿ython 模擬員工信息數(shù)據(jù)庫操作的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10python代碼 if not x: 和 if x is not None: 和 if not x is None:使用
這篇文章主要介紹了python代碼 if not x: 和 if x is not None: 和 if not x is None:使用介紹,需要的朋友可以參考下2016-09-09