数据结构和算法-6-递归

递归不仅是一种算法,也是一种思想,主要是对问题的简化,感觉还是比较重要的,所以这里独立出一篇进行介绍。

定义:

一种方法/函数调用自己的编程技术;

特征:

1. 调用自身, 为了解决更小的问题;

2. 存在某个足够简单的层次, 这一层次不需要调用自身就可以直接解答,并返回结果;

效率:

递归的调用,从调用处转移到方法的开始处,会有一定的额外开销,且中间变量和返回值也会占用系统内存;但使用递归常常是因为, 它从概念上简化了问题,而不是因为它更有效率;

程序设计中的递归, 类似于数学归纳法;

例子:

1. 计算三角数字:三角数字指1,3,6,10,15,21..., 第n项的值 = 第n-1项的值 + n ; 或者说 第n项的值为从1到n的叠加,其算法实现如下:

2. 计算阶乘

3. 计算n次幂(和上面差不多,就不写了)

4. 递归的二分法查找,这个的完整实现在之前介绍数组的文章中已经给出了,所以下面只给出递归部分的代码了

5. 汉诺(hanoi)塔问题:

问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘

分治算法 :

将一个规模为N的问题分解为K个规模较小的子问题,这些子问题相互独立且与原问题性质相同。求出子问题的解,就可得到原问题的解。即一种分目标完成程序算法,简单问题可用二分法完成;

简而言之,把一个大问题分解为多个小问题,往复循环;

递归的二分法查找就是属于分治算法,方法中含有两个对自身的递归调用,但只有一个真的执行了;

之前介绍的排序算法中有一种归并排序,也是对分治算法的一种非常典型的应用,想了解其实现的话可以参考那篇文章;

消除递归:

一个算法作为一个递归的方法通常从概念上很容易理解,但是,实际的运用中证明递归算法的效率不太高,这种情况下,把递归的算法转换成非递归的算法是非常有用的,这种转换经常会用到栈,所以实际中往往一开始就考虑基于栈的算法,而不是从递归的算法转化;

我是今阳,如果想要进阶和了解更多的干货,欢迎关注公众号”今阳说“接收我的最新文章

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.什么是递归 什么是递归递归就是函数(方法)不断调用自身,直至求出结果的算法。 其思路是把一个大问题转化为规模缩...
    王侦阅读 379评论 0 0
  • 数据结构与算法(7)-栈 递归: 在数学与计算机科学中,是指在函数的定义中使用函数自身的方法。也就是说,递归算法是...
    just东东阅读 1,196评论 0 0
  • 递归方法就是直接或者间接的调用自己,它可以将一些发杂问题简化。 递归在下列方法中经常会用到: 定义是递归的。 如斐...
    fuaiyi阅读 210评论 0 0
  • 分治算法介绍 分治法是一种很重要的算法。字面上的解释是“分而治之”,就是把一个复杂的问题分成两个或更多的相同或相似...
    是小猪童鞋啦阅读 688评论 0 0
  • 推荐指数: 6.0 书籍主旨关键词:特权、焦点、注意力、语言联想、情景联想 观点: 1.统计学现在叫数据分析,社会...
    Jenaral阅读 5,751评论 0 5