zhouhao888 2018-12-12 09:58 采纳率: 0%
浏览 1213

小新自学python遇到递归问题,有一点不明白

首先教程里说到递归就是函数自己调用自己,这个还能理解,然后把练习的代码放上。

def sum_numbers(num):
    if num == 1:
        return 1

    temp = sum_numbers(num - 1)

    return num + temp

result = sum_numbers(5)
print(result)
  • 如题在函数,是当数==1的时候就跑出,相当于每一次执行到 temp = sum_numbers(num - 1)的时候只要不==1就会 一直调用函数,因为if里面有return.那么最后一条return num + temp这一条。应该不再 执 行 了。但实际运行的时候还是有执行 的。

  • 当num == 1的时候到了return num + temp的时候这时候temp=1 ,num = 2

  • 但是我不明白num =2是怎么得出 的。再执行 num = 3 temp=3 有点迷糊 了

  • 写回答

2条回答 默认 最新

  • threenewbee 2018-12-12 12:25
    关注

    道理很简单,函数的参数的作用域在函数内,

    sum_numbers(num - 1)
    在外侧调用函数看来,传进去的是num - 1

    在这个函数执行的内部,num变量的值等于外侧num-1

    函数递归,每个递归内的参数和变量,都是独立的。

    好比

    def foo(a):
        print(a)
    
    b = 1
    foo(b)
    

    这段代码,从外侧看,传的是b
    到了函数内,b不见了,a就是b。

    评论

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘