百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>JS教程> JavaScript实现递归算法的办法介绍
分享文章到:

JavaScript实现递归算法的办法介绍

发布时间:09/01 来源:未知 浏览: 关键词:
本篇文章给大家带来的内容是关于JavaScript实现递归算法的办法介绍,有必然的参照 价值,有需要的伴侣可以参照 一下,但愿对你有所帮忙。

我们先来看一下定义。递归算法,是将问题转化为规模缩小的同类问题的子问题,每一个子问题都用一个一样的算法去解决。一样来说,一个递归算法就是函数调取本身去解决它的子问题。

  递归算法的特点:

  1. 在函数历程中调取本身。
  2. 在递归历程中,必需有一个明白的前提推断递归的完毕,既递归出口。
  3. 递归算法简约但效力低,平常不作为引荐算法。

  上面这些是baidu百科的说明,讲的也是十清楚确,大家配合实例来细细揣摩。

  阶乘

  问题描写: n! = n*(n-1)*...2*1

  代码实现:

下载.png

  我们拿到问题的时候,我们依照定义的说明,可以先将规模缩小到同类的子问题。比方,n! 是等于 n* (n-1)!,然后(n-1)! = (n-1)*(n-2)!。这样顺次往下推,直到if的出口。这里用了arguments.callee,是为了防止函数名的严密耦合,在这里它等同于factorial(n-1)。函数实现起来是不是简约明了呢。当然由于问题规模简便,其有用轮回也是可以实现的,大家可以尝试一下。

斐波那契数列

  问题描写:1, 1, 2, 3, 5, 8, 13, 21, 34, ....... 求第n个数是多少。

  代码实现:

  下载 (1).png

  其有用方才的设法实现,也是非常的简便的。通过剖析可以得到第n个数,是前两个数的和,通过这个我们就可以通过递归,不竭获得所需要的前两个数,直到n<= 2这个前提返回1。

  走楼梯问题

  问题描写:楼梯有n阶台阶,上楼可以一步上1阶,也可以一步上2阶或者3阶,运算共有多少种不一样的走法。

  代码实现:

  下载 (2).png

  这其实就是一个斐波那契数列的一种实现。我们剖析的时候,可以转化成小规模的子类问题。当抵达指定阶梯的最后一步的时候,可以有三种种状况,一是上一步,二是上两步,三是上三步。所以总的办法是F(n) = F(n-1) + F(n-2) + F(n-3)。然后天然就成了各自的小运算,不竭轮回下去,直到推断前提的发生。

  最大公约数

  问题描写:给两个数,假如两个数相等,最大公约数是其本身。假如不等,取两个数相减的绝对值和两个数中最小的数比力,相等则为最大公约,不等则连续上面的算法,直到相等。

  代码实现:

  下载 (3).png

  没什么好说的,照问题描写所要求的实现就可以了。递归的出口便在于a等于b。

 汉诺塔

  问题描写:大家都或多或少的玩过,这里就不再赘述了。

  代码实现:

  下载 (4).png

  在我没有体味到递归的精粹前,我对这个问题几乎百思不得其解。我不断问本人,我如何知道下一个该去哪里?后来,我就知道,我其实更关怀的是,最后那一个该如何走。这个如何说呢?我们可以从头想起,我们假如只要1个盘,我们可以让它到C柱,也可以到B柱。天然两个盘,也可以实现。3个盘,也是可以的吧。那我们就讲4个盘的状况。4个盘要完成就要将A上的圆盘,完全转移到C上。我们把前3个盘当作一个团体放到B上,然后第4个盘就可以到C上了,然后我们再将前三个放到C上,就成功了。那前三个盘,又可以从新当作一个新游戏,让前两个盘,当一个团体,顺次类推。这样我们只需要关怀大的团体的事,其它的就转成小规模问题解决就好了。

二分法快排

  问题描写:使用二分法,对一个数组停止由小到大的排序。

  代码实现:

  下载 (5).png

嗯...第二次写这东西啦。这一次对递归的实现也是比上次清楚许多了。其实也是将大规模化为小规模,关怀一个大团体,让其不竭化为小规模停止运算。详细可以去本来那篇随笔停止查看。

DOM树的递归

问题描写:猎取一个节点的所有父节点的tagName

代码实现:

  下载 (6).png

大约都能看懂就不说什么啦。比拟此前的汉诺塔和快排什么的,这个还是挺简便的了,但是最接近我们JavaScript的实际利用。

本篇文章到这里就已经全部完毕了,更多其他出色内容可以关注PHP中文网的JavaScript视频教程栏目!

以上就是JavaScript实现递归算法的办法介绍的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板