C语言中关于函数递归的理解

递归的概念:如果一个对象部分包含它自己,或者利用自己定义自己,则称这个对象是递归的;如果 一个过程直接或间接调用自己,则称这个过程是一个递归过程。递归的主要思考方式在于:将大事化小

我们先看一个例子

题目:输入一个无符号数,并输出这个数的每一位

cpp 复制代码
​#include"stdio.h"
void print(unsigned int n)        
{
    if(n>9)
        print(n/10);
    printf("%u ",n%10);
}
int main()
{
    unsigned int num=0;        //unsigned:无符号类型
    scanf("%u",&num);          //%u 无符号的数据类型
    print(num);
    return 0;
}

​

那么我们来看看具体的运行方式:

注意:函数每次递归都会开辟出一个空间,也称为栈,而执行完这个栈里面的所有东西之后,这个栈就会被销毁

现在已经把条件执行完了,那么接下来就要开始返回了

相关推荐
森林里的程序猿猿15 分钟前
并发设计模式
java·开发语言·jvm
222you24 分钟前
四个主要的函数式接口
java·开发语言
smchaopiao2 小时前
Python中字典与列表合并的问题与解决方法
开发语言·python
敲代码的瓦龙2 小时前
Java?面向对象三大特性!!!
java·开发语言
2501_921649492 小时前
期货 Tick 级数据与基金净值历史数据 API 接口详解
开发语言·后端·python·websocket·金融·区块链
野犬寒鸦2 小时前
Redis复习记录day1
服务器·开发语言·数据库·redis·缓存
小菜鸡桃蛋狗2 小时前
C++——类和对象(下)
开发语言·c++
骑龙赶鸭2 小时前
java开发项目中遇到的难点,面试!
java·开发语言·面试
张人玉2 小时前
C#通讯(上位机)常用知识点
开发语言·c#·通讯·上位机开发