python递归(返回、闭包)函数

函数调用函数自身,这种方式称为递归,这种函数称为递归函数

递归函数的优点是定义简单,逻辑清晰,缺点是过深的调用会导致栈溢出

递归函数使用过程中,需要找到不变的规律和停止递归的边界条件
因为函数自身调用自身,函数本身的结构不变,只是每次传的参数改变

递归实现过程(扩展):利用栈的思想,先找边界条件,同时将后面的任务存起来,一直到最前面的边界条件,然后回去,每次从栈中取任务,进行计算,一直到最后一个任务取完,结果也计算完毕

递归过程:

​ 递归前进段

​ 递归边界条件

​ 递归返回段

例子

递归求100以内偶数和

def mysum(n):
    """n以内所有偶数和"""
    if n == 0:
        return 0
    else:
        return mysum(n-2) + n
# 
r = mysum(100)
print(r)

递归实现斐波那契

def fibonacci(n):
    if n == 1 or n == 2:
        return 1
    else:
        return fibonacci(n - 1) + fibonacci(n - 2)


r = fibonacci(5)
print(r)

返回函数

def outer():
    def inner():
        print("hello world")

    # 将内层函数名 作为 外层函数的 返回值 返回
    return inner


r = outer()
print(r)
r()  # 执行r,也就是执行内层函数 inner

函数的返回值不是普通的值,而是另一个函数的名字

闭包函数

定义
  • 结构是一个嵌套函数
  • 外层函数返回内层函数的引用(名字)
  • 内层函数使用外层函数的临时变量
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值