鱼C论坛

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

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

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

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

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

x
Python FAQ 011 递归(三)


问题

下面的代码为何只返回了数字的个位 ?

  1. def get_digit(n):
  2.     result = []
  3.     if n > 0:
  4.         result.insert(0, n % 10)
  5.         get_digit(n // 10)
  6.         return result


  7. print(get_digit(12345))
复制代码


答案

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

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

让我们打印一下 result:

  1. def get_digit(n):
  2.     result = []
  3.     if n > 0:
  4.         result.insert(0, n % 10)
  5.         get_digit(n // 10)
  6.         print(result)
  7.         return result


  8. print(get_digit(12345))
复制代码


执行结果:

  1. [1]
  2. [2]
  3. [3]
  4. [4]
  5. [5]
  6. [5]
复制代码


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

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

  1. result = []


  2. def get_digit(n):
  3.     if n > 0:
  4.         result.insert(0, n % 10)
  5.         get_digit(n // 10)
  6.         return result


  7. print(get_digit(12345))
复制代码


或者使用闭包:

  1. def get_digit(number):
  2.     result = []

  3.     def funin(n):
  4.         if n > 0:
  5.             result.insert(0, n % 10)
  6.             funin(n // 10)
  7.             return result

  8.     return funin(number)


  9. print(get_digit(12345))
复制代码


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

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-8 04:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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