news 2026/4/28 21:34:38

【递归入门】---- 识别递归问题 + 三步写出正确代码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【递归入门】---- 识别递归问题 + 三步写出正确代码

1. 题目描述:求“数根”问题

题目链接

给定正整数n nn(如 38),不断将其各位数字相加,直到结果为一位数。

38 → 3+8=11 → 1+1=2 → 输出 2

这道题可用循环轻松解决,但我们的目标是:用递归来写,并从中提炼通用方法


2. 什么样的问题适合用递归?

不是所有问题都值得用递归。真正适合递归的问题,通常具备以下三个特征

特征 1:自相似性(Self-similarity)

问题的结构在不同规模下“看起来一样”。

  • 数根:f(n) = f(各位和)→ 问题形式完全相同

  • 阶乘:n! = n × (n-1)!

一句话判断

如果你能用“……的……”来描述问题(如 n 的数根 =(n 的各位数字之和)的数根。),那它很可能适合递归。


特征 2:存在明确的最小情况(Base Case)

必须有无需递归就能直接回答的情形。

  • 数根:n < 10→ 直接返回n
  • 阶乘:0! = 1

没有基线条件 → 无限递归 → 栈溢出!


特征 3:每次递归让问题变小并趋近基线

参数必须朝着终止条件收敛。

  • n → sum_of_digits(n)(38 → 11 → 2)
  • n → n-1(阶乘)

❌ 如果递归后问题没变小(如f(n) = f(n)),就会死循环。


3. 如何写出正确的递归程序?——三步心法

掌握了“识别”,接下来是“构造”。我们用递归三步心法来写“数根”:


第一步:写出基线条件(Base Case)

:什么情况下,我不需要再递归?

对数根:
→ 如果n < 10,它本身就是答案!

if(n<10){returnn;// 出口!}

技巧:先写这一行,避免忘记出口。


第二步:定义递归关系(Recursive Step)

:当前问题能否转化为一个“更小”的同类问题?

对数根:
→ 先算各位和x,然后求x的数根!

returncalc(x);// 问题规模缩小

关键心态

不要试图脑内展开所有调用!
只需相信:calc(x)能正确返回x的数根。你只负责当前层。


第三步:实现“缩小问题”的工具

有时需要一小段逻辑生成子问题输入。

对数根:计算各位和:

intx=0;while(n){x+=n%10;n/=10;}

这段代码不属于递归思想本身,只是辅助。可内联,也可拆成独立函数。


完整代码:三步合一

#include<bits/stdc++.h>usingnamespacestd;intcalc(intn){// 第一步:基线条件if(n<10)returnn;// 第三步:工具——计算各位和intx=0;while(n){x+=n%10;n/=10;}// 第二步:递归调用(问题变小)returncalc(x);}intmain(){intn;cin>>n;cout<<calc(n)<<endl;return0;}

安全(递归深度 ≤ 3)
正确(符合数学定义)
清晰(三步结构分明)


4. 避坑指南

错误表现解决方案
忘记基线条件栈溢出先写if (base) return ...
问题没变小无限递归检查参数是否真的缩小(如n → x < n
过度复杂化逻辑混乱只专注当前层:判断 → 缩小 → 调用

口诀
“先写出口,再缩问题,相信子问题能搞定。”


5. 总结

  • 适合递归的问题 = 自相似 + 有出口 + 能缩小
  • 写递归的三步心法
    1️⃣ 写基线条件(先保命)
    2️⃣ 定义递归关系(信子问题)
    3️⃣ 实现缩小工具(辅助逻辑)
  • 不要怕递归——它只是“让问题自己解决自己”的思维方式。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 17:35:49

LobeChat Docker镜像下载地址与验证方法全记录

LobeChat Docker 镜像安全获取与验证实战指南 在 AI 应用快速落地的今天&#xff0c;越来越多开发者选择通过容器化方式部署大语言模型前端系统。LobeChat 作为一款基于 Next.js 的现代化开源聊天界面&#xff0c;凭借对 OpenAI、Ollama、Hugging Face 等多种后端的良好支持&a…

作者头像 李华
网站建设 2026/4/28 17:23:00

9个AI写作工具,专科生轻松搞定论文格式!

9个AI写作工具&#xff0c;专科生轻松搞定论文格式&#xff01; AI写作工具&#xff0c;让论文写作不再难 在当今信息化时代&#xff0c;AI写作工具已经成为学生和科研工作者不可或缺的助手。特别是对于专科生而言&#xff0c;面对繁重的论文任务&#xff0c;如何高效地完成格式…

作者头像 李华
网站建设 2026/4/16 13:59:25

小白也能懂:LobeChat五大核心功能通俗讲解

小白也能懂&#xff1a;LobeChat五大核心功能通俗讲解 你有没有想过&#xff0c;自己也能拥有一个像ChatGPT那样聪明、能聊会写的AI助手&#xff1f;不是用别人的网页版&#xff0c;而是真正属于你的——可以部署在内网、连接本地模型、上传私人文档、甚至让它帮你查天气、写邮…

作者头像 李华
网站建设 2026/4/25 13:01:46

分支和循环

C语⾔是结构化的程序设计语⾔&#xff0c;这⾥的结构指的是顺序结构、选择结构、循环结构&#xff0c;C语⾔是能够实 现这三种结构的&#xff0c;其实我们如果仔细分析&#xff0c;我们⽇常所⻅的事情都可以拆分为这三种结构或者这三种 结构的组合。 我们可以使⽤ if 、 switch…

作者头像 李华
网站建设 2026/4/27 9:26:40

Dify与Spring AI性能对比(从吞吐量到内存占用的全面剖析)

第一章&#xff1a;Dify与Spring AI性能对比的背景与意义随着企业级AI应用的快速发展&#xff0c;选择合适的AI开发框架成为系统性能与可维护性的关键。Dify与Spring AI作为当前主流的两类AI集成方案&#xff0c;分别代表了低代码平台与传统编程框架的技术路径。Dify以可视化编…

作者头像 李华
网站建设 2026/4/27 23:28:55

揭秘Dify检索重排序机制:如何通过参数调优实现精度提升30%以上

第一章&#xff1a;揭秘Dify检索重排序的核心机制 在构建高效、精准的AI应用时&#xff0c;检索增强生成&#xff08;RAG&#xff09;系统中的排序环节至关重要。Dify作为领先的低代码AI应用开发平台&#xff0c;其内置的检索重排序&#xff08;Re-ranking&#xff09;机制显著…

作者头像 李华