鱼C论坛

 找回密码
 立即注册
查看: 2053|回复: 0

[技术交流] Python FAQ 011 递归(三)

[复制链接]
发表于 2020-3-4 12:25:44 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
Python FAQ 011 递归(三)


问题

下面的代码为何只返回了数字的个位 ?
def get_digit(n):
    result = []
    if n > 0:
        result.insert(0, n % 10)
        get_digit(n // 10)
        return result


print(get_digit(12345))

答案

是因为 result = [] 这一句放在函数内部而出错的。

如果 result = [] 放在函数内部,每次递归 result 都会被清空。

让我们打印一下 result:
def get_digit(n):
    result = []
    if n > 0:
        result.insert(0, n % 10)
        get_digit(n // 10)
        print(result)
        return result


print(get_digit(12345))

执行结果:
[1]
[2]
[3]
[4]
[5]
[5]

可以看到 result 始终只有一个元素。

要解决这个问题,可以将 result 放在函数外面:
result = []


def get_digit(n):
    if n > 0:
        result.insert(0, n % 10)
        get_digit(n // 10)
        return result


print(get_digit(12345))

或者使用闭包:
def get_digit(number):
    result = []

    def funin(n):
        if n > 0:
            result.insert(0, n % 10)
            funin(n // 10)
            return result

    return funin(number)


print(get_digit(12345))

两种方法的执行结果都为 [1, 2, 3, 4, 5] 。

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-23 21:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表