鱼C论坛

 找回密码
 立即注册
查看: 2129|回复: 4

[已解决]两个简单的递归,但结果不同

[复制链接]
发表于 2017-3-7 10:50:00 | 显示全部楼层 |阅读模式

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

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

x
各位,小弟遇到如下两个递归的函数,但两个函数看起来差不多,但运行后的结果不同,代码如下:

  1. def function1(length):
  2.     if length > 0:
  3.         print(length)
  4.         function1(length - 1)
  5. def function2(length):
  6.     while length > 0:
  7.         print(length)
  8.         function2(length - 1)
复制代码


例如,调用 function1(3), 输出结果为
3
2
1

但调用function2(3), 输出结果为
3
2
1
1
...
1
将会无限循环下去
小弟在Visualize python中运行function2,没有看懂红色字迹部分,为什么在 while 0>0: 这句返回值为None,0>0,不应该返回 False 吗?
所以,仍旧不明白 function2为什么会是死循环,望达人指教
Screen Shot 2017-03-06 at 18.48.06.png
最佳答案
2017-3-7 10:58:58
if length > 0这个判断后,if中的语句只会执行一遍
但是while length > 0这一句,你最后调用到1的时候 length == 1 一直大于0
执行完循环体后回来判断还是大于0这样就会一直循环
红字部分是你工具循环了1000次后自动帮你停下你的循环,防止一直占用内存,建议你修改你的代码,减少循环次数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-3-7 10:56:00 | 显示全部楼层
第二个不会无限循环下去,但是在循环结束之前,会到达递归最大次数终止,防止系统崩溃。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-7 10:58:58 | 显示全部楼层    本楼为最佳答案   
if length > 0这个判断后,if中的语句只会执行一遍
但是while length > 0这一句,你最后调用到1的时候 length == 1 一直大于0
执行完循环体后回来判断还是大于0这样就会一直循环
红字部分是你工具循环了1000次后自动帮你停下你的循环,防止一直占用内存,建议你修改你的代码,减少循环次数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-7 12:27:23 | 显示全部楼层
应该是函数值默认返回none,最后一句改为 return function2(length-1)试试。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-7 22:19:39 | 显示全部楼层
你的 while length > 0:程序块里没有break,就是死循环吧。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 07:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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