函数及递归调用实例(递归翻转字符串和汉诺塔问题)

函数

可变参数传递

在这里插入图片描述

例:求n的阶乘和某一些数的乘积

def fact(n, *b):
    s = 1
    for i in range(1, n + 1):
        s *= i
    for item in b:
        s *= item
    return s
print(fact(10, 3, 5, 8))

在这里插入图片描述

返回值

return 可以返回多个结果, 也可以不返回结果

def fact(n, m = 1):
    s = 1
    for i in range(1, n + 1):
        s *= i
    return s // m, n, m
a, b, c = fact(10, 5)
print(a, b, c)

局部变量与全局变量

三个使用规则

在这里插入图片描述

规则一:

在这里插入图片描述

函数运算结束后,局部变量将被释放

在函数内部使用全局变量,使用保留字global

在这里插入图片描述
规则二:局部变量为组合数据类型切未创建,等同于全局变量

在这里插入图片描述

注意:在函数中未被创建

lambda函数

谨慎使用lambda函数,推介使用def定义

在这里插入图片描述

递归实例:字符串翻转

#递归字符串翻转
def rvs(s):
    if s == "":
        return s
    else:
        return rvs(s[1:] + s[0])

递归实例:汉诺塔问题

#汉诺塔问题
count = 0
def hanoi(n, src, dst, mid):
    global count
    if n == 1:
        print("{}:{}->{}".format(1, src, dst))
        count += 1
    else:
        hanoi(n - 1, src, mid, dst)
        print("{}:{}->{}".format(n, src, dst))
        count += 1
        hanoi(n - 1, mid, dst, src)
hanoi(3, "A", "C", "B")
print(count)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值