前言
各位师傅们好,我是qmx_07,今天我们来讲解函数递归,之后的文章还会持续更新!
函数递归
递归的思想
把⼀个⼤型复杂问题层层转化为⼀个与原问题相似,但规模较⼩的⼦问题来求解;直到⼦问题不能再 被拆分,递归就结束了。所以递归的思考⽅式就是把⼤事化⼩的过程
递归中的递就是递推的意思,归就是回归的意思
递归的限制条件
递归在书写的时候,有2个必要条件:
1.递归存在限制条件,当满⾜这个限制条件的时候,递归便不再继续
2.每次递归调⽤之后越来越接近这个限制条件
递归案例
1.求n的阶乘
⼀个正整数的阶乘(factorial)是所有⼩于及等于该数的正整数的积,并且0的阶乘为1。
也就是 5! , 5*4*3*2*1
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int Fact(int n)
{
if (n == 0)
{
return 1;
}
else
{
return n * Fact(n - 1);
}
}
int main()
{
int n = 0;
printf("请写出您想要求阶乘的数字:");
scanf("%d", &n);
int result = Fact(n);
printf("%d的阶乘是:%d", n, result);
return 0;
}
阶乘递归的思路剖析
阶乘递归的画图表示
案例2:顺序打印一个整数的每一位
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
void Print(int n)
{
if(n > 9)
{
Print(n / 10);
}
printf("%d ",n % 10);
}
int main()
{
int n = 0;
printf("请输入一个整数:");
scanf("%d", &n);
Print(n);
return 0;
}
顺序打印整数 递归的思路剖析
顺序打印整数 递归的画图表示
函数栈帧问题
在C语⾔中每⼀次函数调⽤,都要需要为本次函数调⽤在栈区申请⼀块内存空间来保存函数调⽤期间 的各种局部变量的值,这块空间被称为运⾏时堆栈,或者函数栈帧。
函数不返回,函数对应的栈帧空间就⼀直占⽤,所以如果函数调⽤中存在递归调⽤的话,每⼀次递归 函数调⽤都会开辟属于⾃⼰的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间
所以如果采⽤函数递归的⽅式完成代码,递归层次太深,就会浪费太多的栈帧空间,也可能引起栈溢 出(stackoverflow)的问题。