【C语言】-递归

1、递归概念

递归(Recursion)是编程中一种重要的解决问题的方法,其核心思想是函数通过调用自身来解决规模更小的子问题,直到达到最小的、可以直接解决的基准情形(Base Case)。
在这里插入图片描述

核心:自己调用自己
必要条件:

  • 基准情形(base case):函数不再递归调用的终止条件,避免无限循环;
  • 递归步骤(Recursive step):将原问题分解为规模更小的子问题,并通过递归调用解决。(每次递归调用后,越来越接近终止条件).

2、递归的应用场合

  • 数学问题:阶乘计算、斐波那契数列、最大公约数
  • 数据结构遍历:树的遍历、图的深度优化搜索、链表操作(反转、查找)
  • 分治算法:快速排序、归并排序、汉诺塔问题
  • 其它:目录结构遍历、格式解析(JSON/XML)

3、递归的实现

/* 阶乘函数 */
int factorial(int n) {// 基准情形if (n == 0) return 1;// 递归步骤return n * factorial(n - 1);
}/* 二叉树遍历,前序 */
struct TreeNode {int data;struct TreeNode* left;struct TreeNode* right;
};void preOrderTraversal(struct TreeNode* root) {if (root == NULL) return;  // 基准情形printf("%d ", root->data);  // 访问根节点preOrderTraversal(root->left);  // 递归左子树preOrderTraversal(root->right);  // 递归右子树
}

尾递归(Tail Recursion)
尾递归是递归编程的一种特殊形式,其核心特点是:递归调用是函数的最后一个操作,且返回值不参与任何计算。这种结构允许编译器将递归优化为迭代,避免栈溢出风险。
(1)普通递归 vs 尾递归

// 普通递归阶乘(非尾递归):递归调用后还需进行额外计算(如乘法、加法)
int fact(int n) {if (n == 0) return 1;return n * fact(n-1);  // 递归调用后需进行乘法运算
}// 尾递归阶乘:递归调用是最后一步,结果直接返回。
int fact_tail(int n, int acc) {if (n == 0) return acc;return fact_tail(n-1, n * acc);  // 递归调用是最后操作,无后续计算
}

(2)关键特征

  • 最后操作:递归调用必须是函数的最后一条语句。
  • 无后续计算:返回值直接来自递归调用,不参与额外运算。
  • 累加器参数:通常引入额外参数(如acc)保存中间结果

(3)尾递归的优缺点
优点

  • 避免栈溢出:优化后等效于迭代,栈空间复杂度为 O (1)。
  • 代码简洁:保持递归的逻辑清晰性,同时获得迭代的性能。

缺点

  • 依赖编译器优化:C 语言标准并未强制要求尾递归优化,部分编译器(如 GCC)会自动优化,但并非所有平台都支持。
  • 可读性降低:引入累加器参数可能使代码更难理解(如斐波那契的尾递归版本)。

4、递归的优缺点

优点

  • 代码简洁:直接表达问题的数学定义,减少代码量。
  • 易于理解:对于递归定义的问题(如树结构),逻辑更清晰。
  • 解决复杂问题:适合分治策略,如排序和搜索算法。
    缺点
  • 性能开销:递归调用会消耗栈空间,可能导致栈溢出(Stack Overflow)。
  • 效率问题:某些递归(如斐波那契数列)存在大量重复计算,可用 记忆化(Memoization) 优化。
  • 调试困难:多层递归调用的执行流程复杂,调试时堆栈跟踪较深。

5、常见相关问题

(1)必须确保基准情形存在,否则会导致无限递归,最终引发栈溢出。
(2)注意递归深度,过深建议调整为循环或迭代。
(3)使用打印语句跟踪递归过程,或结合调试器查看调用栈。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/news/908831.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

12.5Swing控件3Jpanel JOptionPane

JPanel JPanel是一个轻量级容器组件,用于组织和管理其他 GUI 组件。它继承自JComponent类,属于javax.swing包,可以容纳按钮、文本框、标签等控件 JPanel 默认使用的布局管理器是 FlowLayout,也可以嵌套其他面板,以便…

MIPI信号为什么不能进行长距离传输

1.关于MIPI信号传输 MIPI信号是不适合长距离传输的。 2.MIPI的信号摆幅小,抗干扰能力比较弱 MIPI信号的差分摆幅比较小,通常只有100mV~200mV,远远低于LVDS的350mV的摆幅 小摆幅信号在长线缆上传输的时候更容易被噪声淹没,信噪比下降&#xf…

Qt的学习(二)

1. 创建Hello Word 两种方式,实现helloworld: 1.通过图形化的方式,在界面上创建出一个控件,显示helloworld 2.通过纯代码的方式,通过编写代码,在界面上创建控件, 显示hello world; …

Windows11+VS2019配置Libigl-2.4.1

Windows11VS2019配置Libigl-2.4.1 由于课题需要,所以出一篇配置Libigl的博客,制作不易,请多多点赞 一、官网下载 官网:https://libigl.github.io/ GitHub下载地址:https://github.com/libigl/libigl 这里我们选择…

地球科学方向(Geoscience and Remote Sensing),1天见刊,当月可检索!

CSP科学出版社,旨在通过为研究人员提供最佳环境来发表、参考、阅读和引用他们的作品,从而为科学界服务。现已与科检易学术达成出版战略合作,现在联合共同出版高质量学术水平的期刊,为方便广大科研学者投稿方便,现已经建…

基于 Three.js 的 3D 模型快照生成方案

基于 Three.js 的 3D 模型快照生成方案 此方案通过 Three.js 渲染场景并异步生成图像数据,同时支持分辨率缩放和 Blob 格式输出,为模型预览、截图保存等需求提供完整解决方案。 问题分析: 使用html2canvas 生成的快照画布显示为空&#xff…

「Java基本语法」变量的使用

变量定义 变量是程序中存储数据的容器,用于保存可变的数据值。在Java中,变量必须先声明后使用,声明时需指定变量的数据类型和变量名。 语法 数据类型 变量名 [ 初始值]; 示例:声明与初始化 public class VariableDemo {publi…

SpringCloud学习笔记-2

说明:来源于网络,如有侵权请联系我删除 1.提问:如果注册中心宕机,远程调用还能成功吗 答:当微服务发起请求时,会向注册中心请求所有的微服务地址,然后在向指定的微服务地址发起请求。在设计实…

Hac - NBh标准JSON协议使用说明文档

Hac - NBh 标准 JSON 协议使用说明文档 一、协议概述 Hac - NBh 标准 JSON 协议是专为物联网设备与服务器数据交互设计的通信协议。以 JSON 格式为基础,采用键值对(KV 值)组织数据,支持灵活选取数据项,通过 CBOR 格式实现高效传输,并利用 AES 128 加密保障数据安全。 …

k8s从入门到放弃之Service负载均衡

k8s从入门到放弃之Service负载均衡 在 Kubernetes (K8s) 中,Service 是一种抽象,它定义了一组逻辑上的 Pod 和访问它们的策略。Service 的主要目的是提供一种可靠的方式来访问一组具有相同标签(Label)的 Pod,即使这些…

【题解-洛谷】P10480 可达性统计

题目:P10480 可达性统计 题目描述 给定一张 N N N 个点 M M M 条边的有向无环图,分别统计从每个点出发能够到达的点的数量。 输入格式 第一行两个整数 N , M N,M N,M,接下来 M M M 行每行两个整数 x , y x,y x,y,表示从 …

SpringCloud2025+SpringBoot3.5.0+gateway+webflux子服务路由报503

文章目录 前言一、问题二、原因1.分析2.配置静态路由再试3.定位 总结 前言 本来昨天就应该也记录下,免得忘记的,但是有点晚了,酒没写,真的是被坑惨了。 当然这也是追求最新的代价,也是对新技术、老知识点的重温…

破解路内监管盲区:免布线低位视频桩重塑停车管理新标准

城市路内停车管理常因行道树遮挡、高位设备盲区等问题,导致车牌识别率低、逃费率高,传统模式在复杂路段束手无策。免布线低位视频桩凭借超低视角部署与智能算法,正成为破局关键。该设备安装于车位侧方0.5-0.7米高度,直接规避树枝遮…

RAG 文档解析难点1:多栏布局的 PDF 如何解析

写在前面 在构建检索增强生成 (Retrieval-Augmented Generation, RAG) 应用时,高质量的数据源是成功的基石。PDF 作为一种广泛使用的文档格式,承载着海量的知识。然而,许多 PDF 文档,特别是学术论文、期刊、杂志和一些报告,都采用了多栏布局 (multi-column layout)。 直…

全面掌握Pandas时间序列处理:从基础到实战

时间序列数据在金融分析、物联网、商业智能等领域无处不在。作为Python数据分析的核心库,Pandas提供了强大而全面的时间序列处理功能。本文将系统介绍Pandas时间序列处理的各个方面,从基础概念到高级应用,帮助您在实际工作中高效处理时间序列…

vscode 离线安装第三方库跳转库

我安装的是C/C的函数跳转 下载的离线库: 项目首页 - vscode代码自动补全跳转插件离线安装包:cpptools-win32.vsix是一款专为VSCode设计的离线安装插件,特别适合无法连接网络的电脑环境。通过安装此插件,您的VSCode将获得强大的代码自动跳转…

GitHub 趋势日报 (2025年06月05日)

📊 由 TrendForge 系统生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日获星趋势图 今日获星趋势图 1472 onlook 991 HowToCook 752 ChinaTextbook 649 quarkdown 451 scrapy 324 age…

关于如何使用VScode编译下载keil工程的步骤演示

1、vscode的插件市场下载keil Assistant 2 、点设置 3、复制keil的地址 4、粘贴到第…

OD 算法题 B卷【最大岛屿体积】

文章目录 最大岛屿体积 最大岛屿体积 大于0的数表示陆地,0表示水,请计算由陆地、水组成的网格中最大岛屿的体积;陆地的数字之和表示所在岛屿的体积,岛屿总是被水包围,并且每座岛屿只能由水平或者垂直方向上相邻的陆地…

一文读懂 Docker Compose(白话版)

一、Docker Compose 是个啥? 想象你开餐厅: 单容器 一个厨师 👨🍳Docker Compose 整个后厨团队 👨🍳👩🍳🧑🍳 菜单 工作流程 用个菜单文件(…