关于递归前后语句执行顺序

当代码位于递归语句前

public static void f(int n) {
    System.out.println(n-1);
    if(n > 1)  f(n-1);
}

f(3) 的执行结果为 :

2
1
0

可见,位于递归语句前的代码是按由外到内的顺序执行的

注意:这里说的是递归语句前的代码是按由外到内的顺序执行的,而不是整个函数的执行顺序,对于整个函数的执行顺序肯定都是从内到外的,因为它是递归嘛

分析

  • 当执行 f(3) 时,在 f(3) 内部的执行顺序为先执行 print(2) 再执行 f(2)
  • 同理,在 f(2) 内部的执行顺序为先执行 print(1) 再执行 f(1)
  • f(1) 只执行 print(0)
  • 最终,执行的顺序为 print(2) -> print(1) -> print(0)

当代码位于递归语句后

public static void f(int n) {
    if(n>1)  f(n-1);
    System.out.println(n-1);
}

f(3) 的执行结果为 :

0
1
2

可见,位于递归语句后的代码是按由内到外的顺序执行的

分析

  • 当执行 f(3) 时,在 f(3) 内部的执行顺序为先执行 f(2) 再执行 print(2)
  • f(2) 内部的执行顺序又是先执行 f(1) 再执行 print(1)
  • f(1) 只执行 print(0)
  • 最终,执行的顺序为 print(0) -> print(1) -> print(2)

当代码位于递归语句前后

public static void f(int n) {
    System.out.println(n-1);
    if(n>1)  f(n-1);
    System.out.println(n+1);
}

f(3) 的执行结果为 :

2
1
0
2
3
4

可见,位于递归语句前后的代码分别按先由外到内,再由内到外的顺序执行的

分析

  • 这次直接用公式进行说明,-> 表示执行顺序
  • f(3) = print(2) -> f(2) -> print(4)
  • f(2) = print(1) -> f(1) -> print(3)
  • f(1) = print(0) -> print(2)
  • 最终 f(3) = print(2) -> print(1) -> print(0) -> print(2) -> print(3) -> print(4)

递归的本质是什么,它并没有那么神秘,这篇文章带你揭开递归的神秘面纱:《递归的本质》

  • 21
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值