• 【递归】什么是递归-C语言为例


    递归是指一个函数在其定义中直接或间接调用自身的编程技巧。在C语言中,递归常用于解决可以被分解为更小的子问题的问题。递归函数通常由两个主要部分组成:

    1. 基准情况这是递归停止的条件,通常是最简单的情况

    2. 递归情况这是函数调用自身的部分,通常涉及到将问题缩小为更小的子问题。

    递归的基本结构

    以下是一个简单的递归函数示例,计算阶乘:

    1. #include
    2. // 计算 n 的阶乘
    3. int fact(int n) {
    4. // 基准情况
    5. if (n == 0) {
    6. return 1; // 0! = 1
    7. }
    8. // 递归情况
    9. return n * fact(n - 1);
    10. }
    11. int main() {
    12. int n = 5;
    13. printf("数字 %d 的阶乘是 %d\n", n, fact(n));
    14. return 0;
    15. }

    递归的特点

    1. 简洁性:递归可以使代码更简洁,特别是在处理分治法问题时。

    2. 易于理解:在某些情况下,递归的逻辑比迭代的逻辑更容易理解。

    3. 内存开销:每次递归调用都需要在栈上分配内存,因此递归深度过大可能导致栈溢出。

    递归的优缺点

    优点
    • 简洁性:递归代码通常比迭代代码更简洁。
    • 自然表达:某些问题(如树的遍历)用递归表达更自然。
    缺点
    • 性能:递归调用会有额外的函数调用开销,可能导致性能下降。
    • 栈溢出:递归深度过大可能导致栈溢出错误。

    常见的递归问题

    1. 阶乘计算:如上所示。
    2. 斐波那契数列:                                                                                                                        
      1. int fib(int n) {
      2. if (n == 0) return 0;
      3. if (n == 1) return 1;
      4. return fib(n - 1) + fib(n - 2);
      5. }
    3. 汉诺塔问题:经典的递归问题,涉及将盘子从一个柱子移动到另一个柱子。
    4. 树的遍历:如前序遍历、中序遍历和后序遍历。

    递归与迭代

            虽然递归和迭代都可以解决相同的问题,但选择哪种方法取决于具体情况。在某些情况下,递归可能更容易实现和理解,而在其他情况下,迭代可能更高效且消耗更少的内存。

    注意

            递归是C语言中一种强大的编程技术,适用于解决许多类型的问题,理解递归的基本原理和如何正确地构建递归函数是编程中的重要技能,在使用递归时,要注意基准情况和递归情况的设计,以避免无限递归和栈溢出。

    觉得有帮助的话点个赞吧!

  • 相关阅读:
    数据结构之算法复杂度篇
    Prometheus(二)基础概念
    STM32F103ZET6_ADC
    网络信息安全实训【SQL注入】
    不要轻易更换zotero同步的官网账号
    PaddleOCR中Android示例Demo编译问题解决
    广州华锐互动VRAR:利用VR开展刑事案件公安取证培训,沉浸式体验提升实战能力
    EasyAVFilter代码示例之将摄像机RTSP流转成RTMP推流输出
    016——DHT11驱动开发(基于I.MX6uLL)
    服务器磁盘配额,限制目录占用磁盘空间
  • 原文地址:https://blog.csdn.net/qq_64108165/article/details/140968116