当前位置:首页 > 创业分享 > 正文内容

什么是递归?一文读懂

福瑞号2023-01-18 23:00:06创业分享308

一.什么是递归?

递归,就是在运行的过程中不断地调用自己。递归有两个过程,简单地说一个是递的过程,一个是归的过程。简单用代码来理解:

public void fun(参数) {

if (终止条件) {

return;

}

fun(参数);

(其他判断条件或语句);

}

在上边代码中,当第一次进入函数时,先判断是否符合终止条件,符合则直接结束函数,不符合入下一语句,调用自己重新进入下一层自身函数,(注意这是最外一层将不向下继续执行语句,外层卡在fun(参数处)),这个调用自己进入自身函数的操作过程即为“递”的过程。假设进入下一层后符合终止条件,返回结果,此时之前进入自身函数执行完成返回最外一层函数,最外一层函数递归调用处得到结果,(即内层函数执行完成得到结果返回值),这个过程即为“归”的过程。这时最外一层函数才能继续执行下一语句,直至函数运行完成。

什么是递归?一文读懂-图1

二.判断递归使用的场景

1.大问题可以拆分为多个子问题。

2.原问题和拆分后的子问题除了数据规模不同,解决思路完全相同。

3.存在递归终止条件。

递归在线性数据结构中使用不太明显,迭代基本可以很容易地解决问题。

递归在非线性结构中非常重要,比如二叉树,回溯,典型的树形问题-九宫格字母组合

三.递归代码的写法,(一定要注意方法的语义)

递归必须具备两个条件,

  • 一是有边界,即终止条件。

  • 二是需要调用自己。

这两个条件缺一不可,并且其中终止条件语句必须在递归调用语句之前。如果顺序颠倒则递归函数会进入死循环,永远退不出来,会出现堆栈溢出异常(StackOverflowError)。

在递归函数中,终止条件可以不止一个,递归调用也可以通过一些逻辑语句分成好几个。

四.讲一个简单且经典的实例(我认为的)

青蛙跳台阶问题:一只青蛙要跳上n层高的台阶,一次能跳一阶,也可以跳2阶,请问这只青蛙跳上n层高的台阶有多少种跳法?

问题解决:这个问题有好几种解法,这里就讲递归方法,这个问题需要逆向思维,如果从第一个台阶就开始算,就比较难想到终止条件,以及递归调用方式。我们可以让青蛙下台阶,一次可以下一个,也可以下两个。这时我们可以知道:

当n=1时,只有一种方法。

当n=2时,有两种方法。

其n>2时,青蛙可以选择跳两层台阶,也可以选择跳一层台阶。

以上我们可以得到,终止条件为台阶剩下1或2层时可以直接得到结果,即为边界。当n>2时我们可以使用递归语句调用自身。这样就可以写出递归代码:

public int climbStairs(int n){

//终止条件

if(n == 1)

return 1;

if(n == 2)

return 2;

//递归调用,此时青蛙可以选择跳一阶也可以跳两阶,所以将两种情况相加起来

return climbStairs(n-1) + climbStairs(n-2);

扫描二维码推送至手机访问。

版权声明:本文由福瑞号发布,如需转载请注明出处。

本文链接:http://furui.com.cn/42623.html

标签: 什么是递归

“什么是递归?一文读懂” 的相关文章

霍利菲尔德战绩详细资料(盘点一下打败或战平霍利菲尔德的对手)

霍利菲尔德战绩详细资料(盘点一下打败或战平霍利菲尔德的对手)

伊万德.霍利菲尔德是一位辉煌与争议并存的世界拳王,曾经获得WBC/WBA/IBF次重量级/重量级冠军,其中先后五次获得世界冠军头衔,四次获得WBA(世界拳击协会)重量级冠军头衔。霍利菲尔德职业生涯共取得42胜10负2平的战绩,先后输过九位拳手,这里就盘点一下他职业生涯输掉及平局的十二场比赛。 1...

中国主持人排名前十名(中国知名的十位主持名嘴)

中国主持人排名前十名(中国知名的十位主持名嘴)

1.何炅,1974年4月28日出生于湖南省长沙市雨花区,男主持人,演员,歌手,导演和男演员。中国大陆主持人,毕业于北京外国语大学。何炅集学识、亲和力、机智、控制力与喜感为一体,他从1998年开始主持“快乐大本营”,还主持了“快乐男声”,“超级女声”等,并参加了综艺节目“明星大侦探”等。 2.赵忠祥...

如何拼魔方七个技巧(魔方秘籍)

如何拼魔方七个技巧(魔方秘籍)

魔方 根据视频理解:上 下 左 右 先将白面变好:(1).变一个白十字(如图所示)(2).转好以后检查十字的四个角的颜色(蓝·绿·红·橙)与旁边面上的中心块的颜色是否相同。(有两个相同的时,如果它们相邻,就一个放在后面,一个放在左面(白面朝上),然后:下·右·上·左·下; 如果它们相对,就一个...

明朝内阁首辅周延儒简介(明史:奸臣周延儒两次入阁之路)

明朝内阁首辅周延儒简介(明史:奸臣周延儒两次入阁之路)

明末崇祯朝,出现过许多奇葩事,导致崇祯朝的朝局很不稳定,明朝的灭亡,有相当一部分原因应该归咎于内部的混乱。 比如,崇祯皇帝换宰相频繁,在他执政的十七年时间里,一共更换了五十多位内阁大臣。 其中,内阁首辅就换了十六位,差不多平均每年换一个。 这些首辅大臣,在任时间长的也就五、六年,短则几个月。 下面,...

杨超越为什么火(杨超越为什么这么火)

杨超越为什么火(杨超越为什么这么火)

杨超越——这个今年5月份因为腾讯视频的综艺节目《创造101》火起来的女孩一直备受争议。 争议的原因也很简单:她本身就整个创造101来说,才华不出众、唱歌跳舞也不好、甚至连节拍都掌握不好,可是竟然一直能霸占在前5名。最后更是以第三名的好成绩进入火箭少女。 这也是众多网友很疑惑的问题。那么,...