news 2026/4/23 18:46:55

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

作者头像

张小明

前端开发工程师

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 10:28:12

农业科研人员必看:R语言构建气候-产量响应模型的5大核心步骤

第一章&#xff1a;农业产量的 R 语言气候影响分析在现代农业研究中&#xff0c;准确评估气候因素对农作物产量的影响至关重要。R 语言凭借其强大的统计分析与可视化能力&#xff0c;成为处理气象与农业数据的理想工具。通过整合历史气温、降水量与作物产量数据&#xff0c;研究…

作者头像 李华
网站建设 2026/4/23 12:54:12

装eNSP和VRP的基本控制命令

网络初体验-华为 VRP 系统VRP 介绍通用路由平台VRP&#xff08;Versatile Routing Platform&#xff09;是华为公司数据通信产品的通用操作系统平 台。它以IP业务为核心&#xff0c;采用组件化的体系结构&#xff0c;在实现丰富功能特性的同时&#xff0c;还提供了基于应 用的可…

作者头像 李华
网站建设 2026/4/23 11:29:20

揭秘Dify与Spring AI协同部署难点:5步实现生产环境稳定上线

第一章&#xff1a;揭秘Dify与Spring AI协同部署的核心挑战在构建现代AI驱动的企业级应用时&#xff0c;Dify与Spring AI的集成正逐渐成为开发者关注的焦点。尽管两者分别在可视化AI流程编排和Java生态AI能力扩展方面表现出色&#xff0c;但在实际协同部署过程中仍面临诸多技术…

作者头像 李华
网站建设 2026/4/23 8:52:32

构建高性能NLP流水线:PaddleNLP + github镜像快速拉取模型

构建高性能NLP流水线&#xff1a;PaddleNLP GitHub镜像快速拉取模型 在中文自然语言处理的工程实践中&#xff0c;一个常见的痛点是&#xff1a;明明选好了先进的模型&#xff0c;代码也写得差不多了&#xff0c;结果卡在“下载预训练权重”这一步——进度条爬得比蜗牛还慢&a…

作者头像 李华
网站建设 2026/4/23 8:53:22

Oracle EBS BOM 通过ECO批量新增或者更新资源

通过ECO来新建或者更新BOM Routing对基础数据的要求很高而且总会出些莫名其妙的问题&#xff0c;本人就发现同一批数据没有做任何操作通过多次执行的方式就跑过去了&#xff0c;如果实在执行不过去可以通过控制数据量来执行程序&#xff0c;小批量多次的方式&#xff0c;本身数…

作者头像 李华
网站建设 2026/4/22 20:37:21

【独家揭秘】大型AI项目中Docker-LangGraph多Agent通信的底层原理

第一章&#xff1a;【独家揭秘】大型AI项目中Docker-LangGraph多Agent通信的底层原理在构建复杂的AI系统时&#xff0c;多Agent架构已成为主流选择。Docker与LangGraph的深度集成&#xff0c;为分布式智能体通信提供了轻量级、可扩展的解决方案。其核心在于通过容器化隔离运行环…

作者头像 李华