C语言中的递归函数的简单应用

C语言中的递归函数的简单应用

递归函数

简介

递归函数是指在函数内部调用自身的函数。这种函数可以通过不断调用自身来解决问题,通常用于解决可以被分解为相似子问题的情况。

注意

  1. 递归函数需要有终止条件,否则会导致无限循环,消耗大量资源。
  2. 递归函数的性能可能不如迭代函数,因此在处理大规模数据时需要理性使用。
  3. 递归函数层数太多很有可能会导致栈溢出,特别是在处理大规模数据时需要注意堆栈的大小。
  4. 递归函数要注意内存的使用,避免出现内存泄漏的情况。

使用示例

求n的阶乘

分析问题:

求 n!是一个机械化的连续的单一过程,由此我们可以考虑递归函数

代码示例:

c 复制代码
long long Fact(int n) 
{ 
	if (n < 0) 
         return -1;//错误条件
     else if (n == 0 || n == 1)//基本条件
         return  1;
     else 
		return n * Fact(n-1); 
}

这里我们使用了long long 型整型尽可能的避免数据过大而造成的内存溢出。

同时,我们也应该控制递归的次数,防止栈溢出。

求Fibonacci数列

分析问题:

斐波那契数列是一个经典的数学问题,它是一个无限数列,以0和1开始,后续的每一项都是前两项的和。斐波那契数列的前几项为:0, 1, 1, 2, 3, 5, 8, 13, 21, 34, ...依次类推。

此函数的运算方法单一且连续,所以可以考虑递归函数

代码示例

c 复制代码
long long Fib(int n)
{
    if (n <= 0)
        return -1;//错误条件
    else if (n == 1)
        return 0;
    else if (n == 2)
        return 1;//基本条件
    else
        return Fib(n - 1)+Fib(n-2);
}

求最大公约数

分析问题:

求最大公约数的方法有两种:辗转相减法和辗转相除法。无论是哪一种方法,其实都是多次且单一的运算,所以也可以用递归函数。

代码一:辗转相减法:

c 复制代码
int gcd(int a, int b) 
{
    if (a == b)
    {
        return a;
    }
    if (a > b) 
    {
        return gcd(a - b, b);
    } else 
    {
        return gcd(a, b - a);
    }
}

代码二:辗转相除法:

c 复制代码
int gcd(int a, int b) 
{
    if (b == 0) 
    {
        return a;
    } 
    else 
    {
        return gcd(b, a % b);
    }
}

其实如果我们一步步调试代码(或手动进行递归计算),那么我们可以发现辗转相除法比辗转相减法的递归次数少,所以我们优先选择辗转相除法。

相关推荐
@老蝴9 小时前
C语言 — 通讯录模拟实现
c语言·开发语言·算法
学习噢学个屁14 小时前
基于STM32汽车温度空调控制系统
c语言·stm32·单片机·嵌入式硬件·汽车
共享家952715 小时前
c语言(重点)
c语言·数据结构·算法
iCxhust15 小时前
汇编字符串比较函数
c语言·开发语言·汇编·单片机·嵌入式硬件
我命由我1234517 小时前
STM32 开发 - 中断案例(中断概述、STM32 的中断、NVIC 嵌套向量中断控制器、外部中断配置寄存器组、EXTI 外部中断控制器、实例实操)
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·嵌入式
宋一平工作室18 小时前
单片机队列功能模块的实战和应用
c语言·开发语言·stm32·单片机·嵌入式硬件
SY师弟18 小时前
台湾TEMI协会竞赛——2、足球机器人组装教学
c语言·单片机·嵌入式硬件·机器人·嵌入式·台湾temi协会
whoarethenext18 小时前
使用 C/C++的OpenCV 将多张图片合成为视频
c语言·c++·opencv
梦境虽美,却不长20 小时前
C语言 学习 宏命令(预处理) 2025年6月9日14:41:39
c语言·开发语言·学习
时时三省20 小时前
【时时三省】(C语言基础)将外部变量的作用域扩展到其他文件
c语言