深入浅出,图文并茂,理解递归
2022/10/31 4:24:59
本文主要是介绍深入浅出,图文并茂,理解递归,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
一,简单的递归(求阶乘)
阶乘: n!=1×2×3×…×(n-1)×n
// 例如:求5的阶乘是:1×2×3×4×5 function factorial(n){ if( n<1 ) return return n*factorial(n-1) } console.log(factorial(5)) // 120
二,递归函数的调用顺序
function factorial(n){ console.log(n) if( n<2 ) return 1 let val = factorial(n-1) console.log(val) return n*val }
factorial(5) // 输出: 5,4,3,2,1,1,2,6,24,120
三,解决困惑
1.理解栈结构(后进先出)
这个弹夹相对于子弹来说,是栈结构,因为子弹是后进先出的,我们下面把函数当作子弹。
2.借助开发工具来打断点
1)打开vscode ,输入上面的案例代码,然后打上断点,然后按下 f5 , 通过 “单步调试(f11)”,我们可以看到左侧的调用堆栈在不断的被推入
3.什么时候入栈,什么时候出栈?
1.函数没有 return 的时候,调用了新的函数,就会入栈,return就会出栈。所以 打印入参 是 5,4,3,2,1 。因为这几个入参 都大于等于2 ,所以会走到 第四行,因为是在return之前,所以会入栈。
四,总结
1.理解的函数 的调用堆栈,复杂的递归也可以理解了。 通过第三个部分的方法 ,举一反三,来试着理解下面的代码(归并排序),通过画图的方式去理解效果会更好。
Array.prototype.mergeSort = function () { const rec = (arr) => { if (arr.length === 1) { // 调用堆栈 出栈 return arr; } const mid = arr.length >> 1 const l = arr.slice(0, mid); const r = arr.slice(mid, arr.length); console.log(l,r) const L = rec(l); // 调用堆栈 入栈 const R = rec(r); // 调用堆栈 入栈 const res = []; while (L.length || R.length) { L.length && R.length ? L[0] < R[0] ? res.push(L.shift()) : res.push(R.shift()) : L.length ? res.push(L.shift()) : res.push(R.shift()); } console.log(res) return res; }; const res = rec(this); res.forEach((n, i) => { this[i] = n; }); }; const arr = [11,10,8,7,3]; arr.mergeSort();
这篇关于深入浅出,图文并茂,理解递归的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-24Java中定时任务实现方式及源码剖析
- 2024-11-24Java中定时任务实现方式及源码剖析
- 2024-11-24鸿蒙原生开发手记:03-元服务开发全流程(开发元服务,只需要看这一篇文章)
- 2024-11-24细说敏捷:敏捷四会之每日站会
- 2024-11-23Springboot应用的多环境打包入门
- 2024-11-23Springboot应用的生产发布入门教程
- 2024-11-23Python编程入门指南
- 2024-11-23Java创业入门:从零开始的编程之旅
- 2024-11-23Java创业入门:新手必读的Java编程与创业指南
- 2024-11-23Java对接阿里云智能语音服务入门详解