python74-Python的函数入门,递归函数

本文介绍了函数递归的概念,通过一个数学问题展示了如何使用递归求解,强调了递归必须有明确结束条件以防止无穷递归,并举例说明了递归在遍历未知深度文件夹的应用。
摘要由CSDN通过智能技术生成

在一个函数体内调用它自身,被称为函数递归。函数递归包含了一种隐式的循环,它会重复执行某段代码,但这种重复执行无须循环控制。

例如有如下数学题。已知有一个数列:f(0)=1,f(1)=4,f(n+2)=2*f(n+1)+f(n),其中n是大于0的整数,求f(100)的值。这道题可以使用递归来求得。下面程序将定义一个f(n)函数,用于计算f(100)的值。

# !/usr/bin/env python

# -*- coding: utf-8 -*-

# @Time : 2024/01

# @Author : Laopi

def f(n):

if n==0:

return 1

elif n ==1:

return 4

else:

#在函数体内调用它自身,就是函数递归

return 2*f(n-1)+f(n-2)

#输出fn(10)的结果

print("f(10)的结果是:",f(10))

在上面的f()函数体中再次调用了f()函数,这就是函数递归。注意在f()函数体中调用f()的形式:

return 2*f(n-1)+f(n-2)

对于 f(10),即等于2*f(9)+(8),其中f(9)又等于2 f(8)+f(7)....依此类推,最终会计算到 f(2)等于2*(1)+f(0),即f(2)是可计算的,这样递归带来的隐式循环就有结束的时候,然后一路反算回去,最后就可以得到f(10)的值。

仔细看上面递归的过程,当一个函数不断地调用它自身时,必须在某个时刻函数的返回值是确定的,即不再调用它自身:否则,这种递归就变成了无穷递归,类似于死循环。因此,在定义递归函数时有一条最重要的规定:递归一定要向已知方向进行。

递归是非常有用的,例如程序希望遍历某个路径下的所有文件,但这个路径下的文件夹的深度是未知的,那么就可以使用递归来实现这个需求。系统可定义一个函数,该函数接收一个文件路径作为参数,该函数可遍历出当前路径下的所有文件和文件路径一一在该函数的函数体中再次调用函数自身来处理该路径下的所有文件路径。

总之,只要在一个函数的函数体中调用了函数自身,就是函数递归。递归一定要向已知方向进行

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

软件测试老痞

你的支持,是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值