鱼C论坛

 找回密码
 立即注册
查看: 1312|回复: 5

[已解决]课后练习的疑问

[复制链接]
发表于 2018-4-14 19:56:52 | 显示全部楼层 |阅读模式

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

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

x
TIM截图20180414181115.png

问题:
result.insert(0, n%10) #取出的余数是5,但是为何会放在0的位置上,之后是如何排序的?
get_digits(n//10) #取出的整数值是1234,但是为何在内部调用函数本身

还有内部对12345的分解计算的过程是怎么样的,还请求值大神!
最佳答案
2018-4-14 22:23:24
hi 该题属于递归函数的基础用法

以345为例,分解如下 #12345分解起来太长了,我偷点懒,原理都是一样的

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

  6. 第一轮
  7. n = 345, n>0,if条件有效,345 %10 求余得到 5,result.insert(0,5) ,将5插入到列表result的首位,result当前值为[5]
  8. n // 10 地板除得到 34,即 get_digits(34),开启第二轮

  9. 第二轮
  10. n = 34, n>0,if条件有效,34 %10 求余得到 4,result.insert(0,4) ,将4插入到列表result的首位,result当前值为[4,5]
  11. n // 10 地板除得到 3,即 get_digits(3),开启第三轮

  12. 第三轮
  13. n = 3, n>0,if条件有效,3 %10 求余得到 3,result.insert(0,3) ,将3插入到列表result的首位,result当前值为[3,4,5]
  14. n // 10 地板除得到 0,即 get_digits(0),开启第四轮

  15. 第四轮
  16. n = 0, if条件无效,因此不会调用get_digits()函数了

  17. 该题的注意事项:
  18. (1)递归一定要设定返回条件(例题中通过if条件实现),否则会陷入死循环。递归理解起来确实比较困难,慢慢来 :)
  19. (2)掌握求余、地板除和if语句的基本使用
  20. (3)列表insert方法的使用
复制代码

>>> get_digits(345)
>>> result
[3, 4, 5]
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-4-14 20:25:05 From FishC Mobile | 显示全部楼层
建议用自己的方法去写一个,我写的和这个都不一样,,还是用的递归..你可以再回顾一下insert()的用法,取余和地板除,应该会看得懂,手机回复见谅..
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-14 22:23:24 | 显示全部楼层    本楼为最佳答案   
hi 该题属于递归函数的基础用法

以345为例,分解如下 #12345分解起来太长了,我偷点懒,原理都是一样的

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

  6. 第一轮
  7. n = 345, n>0,if条件有效,345 %10 求余得到 5,result.insert(0,5) ,将5插入到列表result的首位,result当前值为[5]
  8. n // 10 地板除得到 34,即 get_digits(34),开启第二轮

  9. 第二轮
  10. n = 34, n>0,if条件有效,34 %10 求余得到 4,result.insert(0,4) ,将4插入到列表result的首位,result当前值为[4,5]
  11. n // 10 地板除得到 3,即 get_digits(3),开启第三轮

  12. 第三轮
  13. n = 3, n>0,if条件有效,3 %10 求余得到 3,result.insert(0,3) ,将3插入到列表result的首位,result当前值为[3,4,5]
  14. n // 10 地板除得到 0,即 get_digits(0),开启第四轮

  15. 第四轮
  16. n = 0, if条件无效,因此不会调用get_digits()函数了

  17. 该题的注意事项:
  18. (1)递归一定要设定返回条件(例题中通过if条件实现),否则会陷入死循环。递归理解起来确实比较困难,慢慢来 :)
  19. (2)掌握求余、地板除和if语句的基本使用
  20. (3)列表insert方法的使用
复制代码

>>> get_digits(345)
>>> result
[3, 4, 5]
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-15 00:26:24 | 显示全部楼层
thexiosi 发表于 2018-4-14 22:23
hi 该题属于递归函数的基础用法

以345为例,分解如下 #12345分解起来太长了,我偷点懒,原理都是一样的
...

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

使用道具 举报

 楼主| 发表于 2018-4-15 00:27:05 | 显示全部楼层
thexiosi 发表于 2018-4-14 22:23
hi 该题属于递归函数的基础用法

以345为例,分解如下 #12345分解起来太长了,我偷点懒,原理都是一样的
...

非常感谢,一下子就看懂了。你的解题逻辑很顺畅,有什么推荐的提高编程逻辑的书籍么?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-15 07:48:22 | 显示全部楼层
a3522661110 发表于 2018-4-15 00:27
非常感谢,一下子就看懂了。你的解题逻辑很顺畅,有什么推荐的提高编程逻辑的书籍么?

介个...木有啊,不好意思。我解题一般都是用笨办法,简单化、分解进行,编程还是需要多上机实践、多思考,彼此加油
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-10 15:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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