0

0

javascript递归是什么_如何编写递归函数解决问题

夢幻星辰

夢幻星辰

发布时间:2026-01-10 18:47:02

|

957人浏览过

|

来源于php中文网

原创

递归函数需满足三个必要要素:基础情形(终止条件)、递归情形(拆解为更小同类问题)、参数推进(确保趋近终止)。缺一不可,否则易栈溢出或逻辑错误。

javascript递归是什么_如何编写递归函数解决问题

递归函数的本质:函数调用自己

递归不是某种高级技巧,它只是函数在定义或执行过程中直接或间接调用自身的一种写法。关键在于:必须有明确的终止条件(base case),否则会无限调用导致 RangeError: Maximum call stack size exceeded

怎么写一个安全的递归函数:三个必要要素

缺一不可,漏掉任意一个都容易崩:

  • 基础情形(base case):决定何时停止递归,通常是最简单、可直接返回结果的输入,比如 n === 0array.length === 0
  • 递归情形(recursive case):把当前问题拆成“更小的同类问题”,并用函数自身去解决它,比如 factorial(n - 1)
  • 参数推进(progress):每次递归调用必须让参数朝 base case 靠拢,否则就是死循环

例如计算阶乘:

function factorial(n) {
  if (n < 0) return NaN;           // 边界防护
  if (n === 0 || n === 1) return 1; // base case
  return n * factorial(n - 1);      // recursive case,n 每次减 1,向 0 靠拢
}

什么时候该用递归?哪些场景容易翻车

适合递归的问题通常具有「自相似结构」:树遍历、嵌套对象扁平化、深度克隆、分治算法(如快排)、括号匹配等。但要注意:

立即学习Java免费学习笔记(深入)”;

酷表ChatExcel
酷表ChatExcel

北大团队开发的通过聊天来操作Excel表格的AI工具

下载
  • 浏览器环境下,深层递归(>10000 层)大概率触发溢出;Node.js 默认栈大小也有限
  • 递归天然比循环多开销:每次调用要压栈、保存上下文、返回时弹栈
  • 不是所有递归都能轻松转成循环,但多数能 —— 如果性能敏感或数据深度不可控,优先考虑迭代 + 显式栈(Array 模拟)
  • ES2015+ 支持尾调用优化(TCO),但仅限严格模式且只有 Safari 实现了,Chrome/Firefox 均未启用,return factorial(n - 1) 这种纯尾调用也不能指望自动优化

常见错误:你以为在递归,其实没返回值

最隐蔽的坑:忘记在递归分支里写 return,导致函数静默返回 undefined,后续计算全错。

错误示例(查找嵌套对象中的某个 key):

function findKey(obj, target) {
  if (obj && typeof obj === 'object') {
    if (target in obj) return obj[target];
    for (let key in obj) {
      findKey(obj[key], target); // ❌ 缺少 return!这里的结果被丢弃了
    }
  }
}

正确写法:

function findKey(obj, target) {
  if (obj && typeof obj === 'object') {
    if (target in obj) return obj[target];
    for (let key in obj) {
      const result = findKey(obj[key], target);
      if (result !== undefined) return result; // ✅ 显式检查并返回
    }
  }
}

递归的复杂点不在语法,而在逻辑流向是否真正收敛 —— 每一层调用是否真的参与最终结果,这点比写对 base case 还容易被忽略。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1035

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

826

2023.11.06

python如何计算数的阶乘
python如何计算数的阶乘

方法:1、使用循环;2、使用递归;3、使用math模块;4、使用reduce函数。更多详细python如何计算数的阶乘的内容,可以阅读下面的文章。

177

2023.11.13

python求阶乘教程大全
python求阶乘教程大全

本专题整合了python求阶乘相关教程,阅读专题下面的文章了解更多详细内容。

13

2025.11.08

python语言求阶乘
python语言求阶乘

本专题整合了python中阶乘相关教程,阅读专题下面的文章了解更多详细步骤。

43

2025.12.06

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

434

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

600

2023.08.10

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

953

2023.09.19

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

1

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号