五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動態(tài)

Python中遞歸以及遞歸遍歷目錄詳解

發(fā)布日期:2021-12-21 00:03 | 文章來源:腳本之家

遞歸

遞歸的概念:函數(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ù)為去掉當(dāng)前列表第一個元素的新列表

遞歸處理非線性循環(huán)

遞歸還可以處理一些非線性循環(huán),而普通的循環(huán)是無法處理的;比如這樣一個列表對其求和:

L = [1,[2,[3,4],5],6,[7,8]]

由于這個列表不是一個線性迭代,包含著復(fù)雜的元素嵌套,普通的循環(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次遞歸之后,達(dá)到上線,從而報錯

我們也可以手動干預(yù)遞歸的上限,但是這是有風(fēng)險的,要結(jié)合計算機(jī)本身內(nèi)存來考慮

>>> import sys
>>> sys.setrecursionlimit(num)
# num為控制修改的最大遞歸上限次數(shù)

實現(xiàn)Tree命令

核心思路在于,目錄結(jié)構(gòu)的深度及廣度是錯綜復(fù)雜的,通過單純的循環(huán)來做判定是一件非??嚯y的事情

而遞歸恰好適合這樣的非線性循環(huán)問題,當(dāng)然也有一些弊端,當(dāng)目錄結(jié)構(gòu)越來越復(fù)雜,那么程序的執(zhí)行效率會越來越差

import os
def getdir(path, level=0):
 if path == '':
	path = os.getcwd()  # 獲取當(dāng)前的工作目錄
 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)文章希望大家以后多多支持本站!

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部