抹茶吐司 2022-11-04 12:33 采纳率: 57.1%
浏览 22
已结题

python函数中的加法??


def f(n,m):
    if n == 0:
        return m
    elif m == 0:
        return n
    else:
        if n >= m:
            return f(m,n-m) + 1
        else:
            return f(n,m-n) + 2
print(f(3,4))

想问一下这个输出的结果为什么会是7啊,这是怎么运算出来的捏!倒数第二第四行的加法又是怎么运算的呀,😵

  • 写回答

2条回答 默认 最新

  • 快乐鹦鹉 2022-11-04 12:50
    关注

    第一次f(3,4)
    执行
    return f(n,m-n) + 2,即f(3,1) + 2
    f(3,1),执行return f(m,n-m) + 1 = f(1,2) + 1
    f(1,2),执行return f(n,m-n) + 2 = f(1,1) + 2
    f(1,1),执行return f(m,n-m) + 1 = f(1,0) + 1
    f(1,0),满足m==0,执行return n,返回 1
    所以最终f(3,4)的结果是2+1+2+1+1 = 7

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

报告相同问题?

问题事件

  • 系统已结题 12月19日
  • 已采纳回答 12月11日
  • 创建了问题 11月4日

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度