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;
}

​

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

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

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

相关推荐
毕设源码-朱学姐13 小时前
【开题答辩全过程】以 基于Java的失物招领系统设计与实现为例,包含答辩的问题和答案
java·开发语言
Gomiko13 小时前
JavaScript进阶(四):DOM监听
开发语言·javascript·ecmascript
清晓粼溪13 小时前
统一异常处理
java·开发语言
syt_101313 小时前
grid布局之-子项放置4
开发语言·javascript·ecmascript
喵了meme13 小时前
C语言实战2
c语言·开发语言·网络
charlie11451419113 小时前
现代C++工程实践:简单的IniParser3——改进我们的split
开发语言·c++·笔记·学习
fish_xk13 小时前
c++的引用和类的初见
开发语言·c++
yong999014 小时前
水箱水位控制系统MATLAB实现
开发语言·matlab
通往曙光的路上14 小时前
授权vvvvvv
java·开发语言·windows
Data_agent14 小时前
京东商品视频API,Python请求示例
java·开发语言·爬虫·python