一、递归

1、应用场景

  • 遍历文件夹下所有的文件
  • 很多算法离不开递归,例如:快速排序

2、递归的特点

  • 函数内部自己调用自己
  • 必须有出口

3、递归的实现

案例:3以内数字的累加和

# 需求:3以内数字累加和计算:3 + 2 + 1 = 6
# 6 = 3 + 2以内数字累加和
# 2以内数字累加和 = 2 + 1以内数字累加和
# 1以内数字累加和 = 1


# 递归特点:1、函数内部自己调用自己;2、必须有出口
def sum_nums(num):
    # 2.出口
    if num == 1:
        return 1
    # 1.当前数字 + 当前数字-1的累加和
    return num + sum_nums(num - 1)


result = sum_nums(3)
print(result)

二、lambda表达式

1、lambda的应用场景

如果一个函数有一个返回值,并且只有一句代码,可以用lambda简化

2、lambda语法

lambda 参数列表:表达式

注意:

  • lambda表达式的参数可有可无,函数的参数在lambda表达式中完全适用。
  • lambda表达式能接收任何数量的参数但只能返回一个表达式的值。

3、快速入门

# 函数
def fn1():
    return 200


print(fn1)  # <function fn1 at 0x0000021A9A06D2F0>
print(fn1())  # 200

# lambda 匿名函数
# lambda 参数列表:表达式
fn2 = lambda: 200

print(fn2)  # 打印的是lambda的内存地址
print(fn2())  # 200

示例:计算a + b

# 需求:计算任意两个数字的累加和


# 1.函数
def add(a, b):
    return a + b


result = add(2, 6)  # 8
print(result)

# 2.lambda
fn = lambda a, b: a + b
print(fn(2, 5))  # 7

4、lambda的参数形式

  • 无参数
fn1 = lambda: 100
print(fn1())  # 100
  • 一个参数
fn2 = lambda a: a
print(fn2('hello world'))
  • 默认参数/缺省参数
fn3 = lambda a, b, c = 100: a + b + c
print(fn3(11, 22))  # 133
print(fn3(11, 22, 33))  # 66
  • 可变参数:*args
fn4 = lambda *args: args
print(fn4(1, 2, 3))  # (1, 2, 3)
print(fn4(1))  # (1,)
  • 可变参数:**kwargs
fn5 = lambda **kwargs: kwargs
print(fn5(name='python', age=22))  # {'name': 'python', 'age': 22}

5、lambda的应用

5.1 带判断的lambda
# 带判断的lambda
fn1 = lambda a, b: a if a > b else b
print(fn1(1, 111))  # 111
5.2 列表数据排序
students = [
    {'name': 'TOM', 'age': 19},
    {'name': 'Rose', 'age': 29},
    {'name': 'Jack', 'age': 24}
]

# sort(key=lambda..., reverse=bool数据)
# 1. name key对应的值进行升序操作
students.sort(key=lambda x: x['name'])
print(students)

# 2. name key对应的值进行降序排序
students.sort(key=lambda x: x['name'], reverse=True)
print(students)

# 3. age key对应的值进行升序排序
students.sort(key=lambda x: x['age'])
print(students)