鱼C论坛

 找回密码
 立即注册
查看: 1514|回复: 7

[已解决]新手求教 关于函数递归的问题

[复制链接]
发表于 2017-12-19 23:47:00 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 鸣君 于 2017-12-20 09:06 编辑

代码一:
  1. def func(n):
  2.     l=''
  3.     if n:
  4.         l=func(n//2)
  5.         l=l+str(n%2)
  6.         return l
  7.     else:
  8.         return l
  9. print (func(10))
复制代码


代码二:
  1. def get_digits(n):
  2.     l=[]
  3.     if n:
  4.         get_digits(n // 10)
  5.         l.insert(0,n%10)
  6.         return l
  7.     else:
  8.         return l
  9. print (get_digits(100))
复制代码


python 3,windows系统,这是23、24的课后题0和1,为什么代码一的字符串l在每次调用函数时不会重置l='',而代码二的列表l在每次调用函数时会重置l=[]?
最佳答案
2017-12-20 09:14:24
func递归调用进入时也会重置,但因为有返回值,所以每层的结果被重新返回上一层调用了,所以上一层会有之前的结果,get_digits每次递归的结果都没有返回上一层呀,所以每一层的递归结果都是独立的,要把i=[]放在函数外面,这样每次的结果都操作的是一个变量,而不是各个递归内的局部变量,因为递归从最高位开始返回,用l.append(n%10)顺序才是按高位到低位
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-12-20 06:59:37 | 显示全部楼层
本帖最后由 timeislife 于 2017-12-20 07:01 编辑

这里是创建一个同样名字的变量,它们实际上是不一样的,也就是说它们的地址不是一样的,所以没有重置
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-12-20 07:01:52 | 显示全部楼层
有点像那个用global关键字解决的问题
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-12-20 07:02:40 | 显示全部楼层
旧的I变量被屏蔽了,所以才不会被修改
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-12-20 07:21:30 From FishC Mobile | 显示全部楼层
timeislife 发表于 2017-12-20 07:02
旧的I变量被屏蔽了,所以才不会被修改

对,代码二就是用global解决的,但是为什么代码一的字符串l不需要?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-12-20 08:10:07 | 显示全部楼层
我也是一样, 一直搞不明白 函数的嵌套 和递归之类 的东西。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-12-20 09:14:24 | 显示全部楼层    本楼为最佳答案   
func递归调用进入时也会重置,但因为有返回值,所以每层的结果被重新返回上一层调用了,所以上一层会有之前的结果,get_digits每次递归的结果都没有返回上一层呀,所以每一层的递归结果都是独立的,要把i=[]放在函数外面,这样每次的结果都操作的是一个变量,而不是各个递归内的局部变量,因为递归从最高位开始返回,用l.append(n%10)顺序才是按高位到低位
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-12-20 09:26:16 | 显示全部楼层
def get_digits(n):
     l=[]
     if n:
         l=get_digits(n // 10)
         l.append(n%10)
         return l
     else:
         return l

print (get_digits(100))
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-4 23:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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