qq_45379364 2021-08-22 19:31 采纳率: 82.9%
浏览 40
已结题

小白求指导,为啥会出现n=3,2,1

#include<stdio.h>
void up(int);
int main(void)
{

up(1);
return 0;

}

void up(int n)
{
printf("%d: n is %p\n", n, &n);//x
if (n < 4)
up(n + 1);
printf("%d:n is %p\n", n, &n);//y
}
求指导,这段代码,当n=1时,执行x,,n=2,执行x,n=3,执行x,当n=4,执行X并执行有y,执行完Y,应该回到主函数main才对,接着执行UP(1)下面的return=0才对,
为啥实际还会执行n=3 ,2,1呢,这是怎么来的?求指导求指导

  • 写回答

4条回答 默认 最新

  • 全栈极简 博客专家认证 2021-08-22 19:37
    关注

    这就是递归的原理,递归分为递推和回归两个阶段。你的n=3,2,1就是回归阶段的输出。

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

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集