Python 函數(shù)的遞歸詳解
函數(shù)調(diào)用自身的 編程技巧 稱為遞歸。
1.1、遞歸函數(shù)的特點(diǎn)
特點(diǎn):
一個(gè)函數(shù) 內(nèi)部 調(diào)用自己。
函數(shù)內(nèi)部可以調(diào)用其他函數(shù),當(dāng)然在函數(shù)內(nèi)部也可以調(diào)用自己。
代碼特點(diǎn):
1)、函數(shù)內(nèi)部的 代碼 是相同的,只是針對(duì) 參數(shù) 不同,處理的結(jié)果不同;
2)、當(dāng) 參數(shù)滿足一個(gè)條件 時(shí),函數(shù)不再執(zhí)行;
這個(gè)非常重要,通常被稱為遞歸的出口,否則 會(huì)出現(xiàn)死循環(huán)!
def sum_number(num):
print(num)
# 遞歸的出口,當(dāng)參數(shù)滿足某個(gè)條件時(shí),不再執(zhí)行函數(shù)
if num == 1:
return
# 自己調(diào)用自己
sum_number(num - 1)
sum_number(3)
1.2 遞歸案例 ----- 計(jì)算數(shù)字累加
需求:
1)、定義一個(gè)函數(shù) sum_numbers;
2)、能夠接收一個(gè) nums 的整數(shù)參數(shù);
3)、計(jì)算 1 + 2 = num 的結(jié)果;
# 定義一個(gè) 函數(shù) sum_numbers
# 能夠接收一個(gè) num 的整數(shù)參數(shù)
# 計(jì)算 1 + 2 + .... num的結(jié)果;
def sum_numbers(num):
# 1.出口
if num == 1:
return 1
# 數(shù)字的累加 num + 1 (1....num - 1)
# 假設(shè) sum_numbers 能夠正確的處理 1...num - 1
temp = sum_numbers(num - 1)
# 兩個(gè)數(shù)字的相加
return num + temp
result = sum_numbers(2)
print(result)

提示:遞歸是一個(gè) 編程技巧,初次接觸遞歸會(huì)高級(jí)有些吃力 在處理 不確定的循環(huán)條件時(shí),例如:遍歷整個(gè)文件目錄的結(jié)構(gòu)。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Python實(shí)現(xiàn)身份證前六位地區(qū)碼對(duì)照表文件
利用Python對(duì)文件夾下圖片數(shù)據(jù)進(jìn)行批量改名的代碼實(shí)例
Python自動(dòng)化測(cè)試selenium指定截圖文件名的方法
pytorch實(shí)現(xiàn)線性回歸以及多元回歸
使用grappelli為django admin后臺(tái)添加模板
python批量修改圖片尺寸,并保存指定路徑的實(shí)現(xiàn)方法

