python递归_python递归的使用

一、什么是函数递归?

函数的嵌套调用是:函数嵌套函数。函数的递归调用:它是一种特殊的嵌套调用,但是它在调用一个函数的过程中,又直接或间接地调用了它自身。

1.1直接调用

直接调用指的是:直接在函数内部调用函数自身。

import sys

print(sys.getrecursionlimit()) #打印最大递归层数:3000

import sys

sys.setrecursionlimit(10000)

def f(n):

print('from f',n)

f(0)

1.2间接调用

间接调用指的是:不在原函数体内调用函数自身,而是通过其他的方法间接调用函数自身。

def func1():

print('func1')

func2()

def func2():

print('func2')

func1()

递归必须要有两个明确的阶段:

1.递归:一层一层递归调用下去,进入下一层递归的问题规模都将会减小

​ 2.回溯:递归必须要有一个明确的结束条件,在满足该条件开始一层一层回溯。

递归的精髓在于通过不断地重复逼近一个最终的结果。

二、为什么要用递归

递归的本质就是干重复的活,但是仅仅是普通的重复,我们使用while循环就可以了。

比如:计算1+...+5的和

def sum1(i):

if i == 5:

return i

res = sum1(i+1)+i

print(res)

return res

print(sum1(1))

三、如何用递归?

有一个从小到大排列的整型数字列表,我们判断某一个数字是不是在这个列表里面。

动图二分法查找数字7:

lt = [11,33,55,44,77,1,2,86,100]

# 0 1 2 3 4 5 6 7 8

def findnum(f_num,nums):

if not nums:

print('没找到')

return

lens = len(nums)//2

if f_num > nums[lens]:

nums = nums[lens+1:]

findnum(f_num,nums)

elif f_num < nums[lens]:

nums = nums[:lens]

findnum(f_num, nums)

else:

print(f'找到了')

lt.sort()

findnum(7,lt)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值