zhengzaiaining 发表于 2021-7-12 11:18:32

零基础入门学习Python 23、24课后作业第1题

1. 写一个函数get_digits(n),将参数n分解出每个位的数字并按顺序存放到列表中。举例:get_digits(12345) ==>
def get_digits(n):
    list1=[]
    if n:
      get_digits(n//10)
      return list1.append(n%10)
    else:
      return list1
      
print(get_digits(123))

输出:none
请问代码哪里错误呢,递归好难,单步跟踪,显示list1.appand没有把数据加入列表,为什么呢,请各类大佬不吝赐教

qiuyouzhi 发表于 2021-7-12 11:21:16

改成这样:
list1=[]
def get_digits(n):
    if n:
      get_digits(n//10)
      list1.append(n%10)
      
get_digits(123)
print(list1)

Kayko 发表于 2021-7-12 11:29:36

楼上说的对

Twilight6 发表于 2021-7-12 11:31:55



你 list1 放在函数内,属于局部变量,每次递归都会重新赋值,所以你要将递归后的返回值加入前一次递归的列表

另外 append 列表方法是没有返回值的,你设置 returnlist1.append(n%10) 等价于 return None

在你代码基础上改了下顺序,参考代码:

def get_digits(n):
    list1 = []
    if n:
      list1.append(n % 10)
      return get_digits(n // 10) + list1
    else:
      return list1

print(get_digits(123))

zhengzaiaining 发表于 2021-7-12 11:33:58

qiuyouzhi 发表于 2021-7-12 11:21
改成这样:

非常感谢

zhengzaiaining 发表于 2021-7-12 11:34:55

Twilight6 发表于 2021-7-12 11:31
你 list1 放在函数内,属于局部变量,每次递归都会重新赋值,所以你要将递归后的返回值加入前一次递归 ...

非常感谢,您的答案更详细,说的原理也更符合,不好意思,看到的有点晚,非常谢谢

灰晨 发表于 2021-7-12 11:36:01

list1=[],定义空列表要在函数外面
不然每次get_digits(n//10)
list1列表都会重新被定义为空列表

Twilight6 发表于 2021-7-12 11:36:01

zhengzaiaining 发表于 2021-7-12 11:34
非常感谢,您的答案更详细,说的原理也更符合,不好意思,看到的有点晚,非常谢谢



没事~,能解决问题就好

zhengzaiaining 发表于 2021-7-12 11:43:32

灰晨 发表于 2021-7-12 11:36
list1=[],定义空列表要在函数外面
不然每次get_digits(n//10)
list1列表都会重新被定义为空列表

好的好的

zhengzaiaining 发表于 2021-7-12 11:44:44

Twilight6 发表于 2021-7-12 11:36
没事~,能解决问题就好

谢谢,谢谢,正是有你们这样的大佬不吝赐教,才能让小鱼友尽快学会
页: [1]
查看完整版本: 零基础入门学习Python 23、24课后作业第1题