Mr.洋944 2022-10-21 17:17 采纳率: 100%
浏览 18
已结题

初学者搞不懂递归555

#include<stdio.h>
void huan(int a);
int main()
{
int n;
scanf("%d",&n);
huan(n);
return 0;
}
void huan(int a)
{
int b;
scanf("%d",&b);
if(a==1) printf("%d ",b);
else {

    huan(a-1);

printf("%d ",b);
}
}
为甚么会逆序输出

  • 写回答

2条回答 默认 最新

  • 於黾 2022-10-21 17:18
    关注

    因为是先递归后输出,那么当递归完了之后,是从最内层的函数开始返回,返回一个打印一个,所以是最后一个找到的数开始打印的
    类似堆栈,先进后出
    如果把printf写在递归之前,就是正序输出

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

报告相同问题?

问题事件

  • 系统已结题 10月29日
  • 已采纳回答 10月21日
  • 创建了问题 10月21日

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀