内容简介:但这样就会保持10条记录,这样很容易造成栈溢出;我们可以这样理解,执行一个函数A,添加一个记录A,在函数A中调用函数B,添加一个记录B,等函数B执行完了之后,移除记录B,把控制器交给A。因为递归就是函数里面调用函数,所以会有10条记录。这样就只保存一条记录,不会造成栈溢出。而这个为什么只有一条记录呢?这是因为函数fact_iter返回的是它本身,返回本身之后,它就不再需要控制器了(就是没它什么事了,它把任务交个了下家了),所以不会进栈,就不会有这条记录。
一 第一版一版的递归实现 n!,比如 5!= 5 * 4 * 3 * 2 *1
let count = 9000; const fact = (n) => { if (n == 1) { return 1; } else { return n * fact(n - 1); } }; let a = fact(count); //3628800; console.log(a);
但这样就会保持10条记录,这样很容易造成栈溢出;我们可以这样理解,执行一个函数A,添加一个记录A,在函数A中调用函数B,添加一个记录B,等函数B执行完了之后,移除记录B,把控制器交给A。因为递归就是函数里面调用函数,所以会有10条记录。
二、尾递归
const newFact = (n) => { return fact_iter(n, 1); }; const fact_iter = (num, product) => { if (num == 1) { return product; } else { return fact_iter(num - 1, num * product); } }; const b = newFact(count); //3628800; console.log(b);
这样就只保存一条记录,不会造成栈溢出。而这个为什么只有一条记录呢?这是因为函数fact_iter返回的是它本身,返回本身之后,它就不再需要控制器了(就是没它什么事了,它把任务交个了下家了),所以不会进栈,就不会有这条记录。
以上所述就是小编给大家介绍的《js实现递归,尾递归(递归优化),防止栈溢出》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数值方法和MATLAB实现与应用
拉克唐瓦尔德 / 机械工业出版社 / 2004-9 / 59.00元
本书是关于数值方法和MATLAB的介绍,是针对高等院校理工科专业学生编写的教材。数值方法可以用来生成其他方法无法求解的问题的近似解。本书的主要目的是为应用计算打下坚实的基础,由简单到复杂讲述了标准数值方法在实际问题中的实现和应用。本书通篇使用良好的编程习惯向读者展示了如何清楚地表达计算思想及编制文档。书中通过给读者提供大量的可直接运行的代码库以及讲解MARLAB工具箱中内置函数使用的数量方法,帮助......一起来看看 《数值方法和MATLAB实现与应用》 这本书的介绍吧!