zoukankan      html  css  js  c++  java
  • Python第六章-函数04-递归函数和拉姆达表达式

    五、递归函数

    什么叫递归(recusive)?

    你拿两个镜子互相面对着, 然后去看镜子, 会发现每个镜子中很多个镜子, 层层的嵌套, 无穷尽, 这就是一种递归!

    从前有坐山, 山里有座庙, 庙里有个老和尚在给小和尚讲故事: 从前有座山.... 如果你小的时候被人忽悠听过这个故事, 这个故事是递归!

    计算机机中的递归是指: 一个函数在内部自己调用自己, 这就叫函数的递归调用!

    就像前面两种情况一样, 如果不发生点意外, 比如一个镜子被拿走了, 或者老和尚挂了, 则递归无穷尽.

    函数递归一样, 也要有终止条件, 否则就是个死循环!


    所以, 在编程中使用递归一定要注意:

    一定要有结束条件.

    1. 随着递归的深入, 一定要有满足结束条件的情况发生.

    示例代码:使用递归计算数字的阶乘

    def factorial(x):
        """计算参数的阶乘
    
        计算原理: x! = x * (x - 1)!
        当 x == 1 的时候直接返回 1, 而不必再去计算
    
        :param x:  要计算阶乘的数字
        :return:  x!
        """
        if x == 1:
            return 1
        return x * factorial(x - 1)
    
    
    print(factorial(6))
    

    递归可以大大简化我们的代码
    如果你不会用递归, 写出这样的代码, 会被打死的.

    六、 Lambda表达式

    python 对 lambda有比较简单有限的支持.

    lambda 表达式只是对简单到只有一行代码的函数的语法糖(简写), 如果有多行代码, 则无法使用 lambda 表达式.

    但是在别的语言中, lambda 表达式是比较强悍的.

    python 的 lambda 确实比较弱.

    心里时刻想着 lambda 是对只有一行的函数的简写, 你会发现lambda表达式真的很简单!


    6.1 Lambda的语法格式

    语法:

    lambda 形参列表 : 表达式
    

    说明:

    1. 关键字lambda后面紧跟着形参列表. 注意形参列表不能用圆括号括起来
    2. 形参列表后面紧跟着一个冒号(:)
    3. 冒号后面是唯一的表达式. 注意:此表达式必须是合法的表达式.
    4. lambda会自动返回表达式的运算结果.

    6.2 返回一个lambda表达式

    def foo(a):
        return lambda x: x + a
    
    
    f = foo(30)
    
    print(f(20)) # 50
    print(f(40)) # 70
    

  • 相关阅读:
    斐波那契数列的量化分析
    GridView编辑删除操作
    Linux crontab 命令格式与具体样例
    VB.NET版机房收费系统---组合查询
    XMLHTTP使用具体解释
    Android 在子线程中更新UI的几种方法
    国产操作系统剽窃Linux内核可耻!
    Android的PVPlayer介绍
    稀疏矩阵
    很好的理解遗传算法的样例
  • 原文地址:https://www.cnblogs.com/yanadoude/p/12619035.html
Copyright © 2011-2022 走看看