crazy-anonymous 2021-08-03 09:58 采纳率: 100%
浏览 436
已结题

关于python函数递归的问题:

img

img

img

def f(i):
    i += 1
    if i < 5:
        f(i)
    else:
        return i

    
>>> f(1)
>>> print(f(1))
None
>>> def f(i):
    i += 1
    if i < 5:
        return f(i)
    else:
        return i

>>> f(1)
5

昨天学递归, 让我最不懂的就是为什么在 f(i) 前加上return , 这个函数的返回值就变成5了, 不加就返回None?
我的 else 里面的 return 为什么没有返回5?

  • 写回答

2条回答 默认 最新

  • 全栈极简 博客专家认证 2021-08-03 10:06
    关注

    递归包含递推和回归两个阶段,如果没有return就不能保留之前的结果,回归这个阶段就没有值可以计算了。所以必须加return。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月11日
  • 已采纳回答 8月3日
  • 创建了问题 8月3日