C语言递归函数

1.何为递归?

请添加图片描述
学习过高中数列的小伙伴肯定十分熟悉,只要给出前几项,再结合递推公式,所有结果都能求出。而C语言中递归也是如此,一个复杂的过程如果有相似的底层原理,那么可以通过递推回到最简单的初层进行计算,再通过回归计算我们想要的N层

2.递归的要求

请添加图片描述

  1. 能拆分成多个相似的计算过程,即递推公式
  2. 存在限制条件,使递归不断接近这个限制条件,防止死循环

3.递归实例

3.1n!的计算

在这里插入图片描述

在这里插入图片描述
我们按照这个思路写写代码

#include<stdio.h>

int Fact(int n)
{
	if (n == 1)
		return 1;
	else
		return n*Fact(n - 1);
}
int main()
{
	//n!
	int n = 0;
	scanf("%d", &n);
	int ret=Fact(n);
	printf("%d", ret);
	return 0;
}

在这里插入图片描述

3.2顺序打印一个整数的每一位

先用递归的思想思考相似点
%10、/10可以帮助我们逆序得到每一位
请添加图片描述
反向思维,我们可以递推不断/10得到首位,再回归%10
在这里插入图片描述

void Print(int n)
{
	if (n >= 10)
		Print(n / 10);
	printf("%d ", n % 10);
	return;
}

在这里插入图片描述
请添加图片描述

3.3斐波那契数列

a1=1,a2=1,a(n)=a(n-1)+a(n-2);
有了前面的铺垫,代码就都很好实现了;

int Feibo(int n)
{
	if (n == 1 || n == 2)
		return 1;
	else
		return Feibo(n - 1) + Feibo(n - 2);
}

在这里插入图片描述

4递归和迭代

请添加图片描述

看似递归十分好用,却十分容易栈溢出,且无效计算过多

  1. 栈区有限的空间无法支持无限次函数调用,由于每次函数调用都会在栈区预开辟一段空间,相较于迭代在一个函数内多次循环,空间利用效率十分低下,导致栈溢出(空间不足)
    在这里插入图片描述
    2.时间利用效率低下
    正如斐波那契数列代码实现
    在这里插入图片描述
    需要进行多次相同运算,既浪费时间又浪费空间

故一般能用迭代(循环),就不用递归,除非迭代比递归复杂得多且递归能达到目的😊😊😊
请添加图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值