函数三

递归函数

  • 递归是解决问题的一种方式,它的整体思想,是将一个大问题分解为一个个的小问题,直到问题无法分解时,在去解决问题.。
  • 递归式函数有2个条件
    • 基线条件:问题可以被分解为最小问题,当满足基线条件时,递归就不执行了。
    • 递归条件:可以将问题继续分解的条件。
    • 分析:求取 10的阶乘
    # fun(n) 是为了求取n 的阶乘
    def fun(n):
        if n == 1:
            return 1
        return n * fun(n - 1)
    
    
    print(fun(10))
    
  • 求任意数的任意次幂
    def fun(n, m):
        if m == 1:
            return n
        return n * fun(n, m - 1)
    
    
    print(fun(10, 3))
    
  • 回文字符串
    # 首先,基线条件,分别从字符串两边开始取值,直到到最后一个,字符串还剩1个或2个一样的,因此我们可以得到递归的基线条件为 len(str) < 2 才行。
    # 其次,递归条件,通过切片取值,拿到最外层的2个索引的值。
    def fun(n):
        if len(n) < 2:
            return True
        elif n[0] != n[-1]:
            return False
        return fun(n[1:-1])
    
    
    print(fun('123456789987654321'))
    

总结: 递归函数就是在函数中自己调用自己。

高阶函数

  • 接收函数作为参数,或者将函数作为返回值返回的函数就是高阶函数
    def fun1(i):
    	if i % 2 == 0:
            return True
    
    
    def fun2(fn):
        list1 = []
        for i in range(1, 101):
            if fn(i):  # fn(i)  这里fn 是形参,形参等于实参,fn=fun1, 那么 fn(i)==fun1(i)
                list1.append(i)
        return list1
    
    
    print(fun2(fun1))
    

注意:函数调用函数也不一定是 高阶函数!

匿名函数

匿名函数的功能:

  • 防止重名
  • 不用再去定义函数,使用方便
  • 可以作为一个传递的工具

lambda 函数

  • lambda 函数就是匿名函数
    • 语法: lambda 参数:表达式
    print((lambda a, b: a + b)(1,2))
    # 前面括号 a, b 就是形参,后面括号(1, 2) 就是实参~
    list1 = [1, 2, 3, 4, 5, 6, 7, 8]
    s = lambda a: a % 2 ==0
    # filter() 两个参数,第一个参数是过滤规则,第二个参数是过滤的数据
    print(list(filter(s, list1)))
    

闭包

  • 将函数作为返回值也是高阶函数,也称为闭包。
  • 好处
    • 通过闭包可以创建一些只有当前函数能访问的变量。
    • 可以将一些私有数据藏到闭包中。
  • 行成闭包的条件
    • 函数嵌套。
    • 将内部函数作为返回值返回。
    • 内部函数必须要使用到外部函数的变量。
  • 特性: 保证被内部使用的外部变量不被销毁
  • 闭包用多了会导致占用内存较高
    # 定义一个外部函数
    def fun_out(num1):
        # 定义一个内部函数
        def fun_inner(num2):
              res = num1 + num2
              print(res)
        return fun_inner # 因为函数的调用等于函数的返回值
    
    
    f = fun_out(1)
    print(f(2))
    # 有函数嵌套,内部函数作为返回值返回 (return fun_inner), 内部函数使用外部函数的参数 num1,所有上面就是一个 闭包。
    

作业

  1. 猴子吃桃问题(递归):
    猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了,求第一天共摘了多少桃子?
    def f(n):
        if n == 1:
            return 1
        return (f(n - 1) + 1) * 2
    
    
    print(f(10))
    >>> 1534
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Q小松

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值