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

什么是递归?一文读懂

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

一.什么是递归?

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

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

标签: 什么是递归

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

全球十大经济学家排名(举世公认的十大顶尖经济学大师)

全球十大经济学家排名(举世公认的十大顶尖经济学大师)

一、亚当·斯密(1723年—1790年) 经济地位:英国著名经济学家、哲学家、作家,经济学的主要创立者。亚当·斯密是现代资本主义经济制度的创立者,强调自由市场、自由贸易以及劳动分工,被誉为"古典经济学之父""现代经济学之父"。因代表作《国富论》而被认为是古典经济学的“开山鼻祖”,是世界上最为有名的...

世界十大令人惊艳的无人岛(世界十大令人惊艳无人岛排行榜)

世界十大令人惊艳的无人岛(世界十大令人惊艳无人岛排行榜)

来源:排行榜123 许多人应该都曾梦想过到无人岛上去生活,在那里享受都市无法感受到的宁静和天堂一般的美景。今天就由小编来为大家好好介绍一下世界十大令人惊艳的无人岛,快来看看吧,感受一下这令无数人神往的岛屿。 世界十大令人惊艳的无人岛: 1、马尔代夫群岛 2、新西兰奥克兰群岛 3、所罗门群岛的泰特帕雷...

悲伤电影排行榜前十名(十大悲伤虐心电影推荐)

悲伤电影排行榜前十名(十大悲伤虐心电影推荐)

书过警示:以下十部影片非常非常非常的悲伤,极度的虐心,请谨慎考量自身情况后选择观看,观看前请先备好纸巾,然后深呼吸三秒稳定情绪。 文章原创作者-梅书过 ①《美国田园下的罪恶》2007 豆瓣评分8.3 虐心点-托管人的迫害 西尔维亚和妹妹被托付给陌生的格特鲁照看,刚开始时姐妹两与新的伙伴一起玩闹其乐...

张怡宁唯一银牌是输给谁了(张怡宁银牌输给了谁)

张怡宁唯一银牌是输给谁了(张怡宁银牌输给了谁)

张怡宁的银牌输给了王楠。其实大魔王的名字是很多人都知道的,她是那么地霸气,甚至有这样一个传说,那就是在乒乓球比赛中只有一个姓张的,这个人相信大家都是知道的。她打球的时候是非常厉害的,福原爱在看到她穿比赛衣服的时候就觉得害怕,甚至教练都会告诉她让球,这真的是对对方的一种侮辱了。 因为实在是找不到任何...

广东十虎排名谁最厉害(“广东十虎”里)

广东十虎排名谁最厉害(“广东十虎”里)

不知道为什么提到“广东十虎”,我的脑子里第一个想到的就是黄飞鸿,谁想到他居然不是十虎之一。 这也是没办法的事,毕竟我们大多数人都是因为黄飞鸿的众多电影电视剧,才明白了原来还有“广东十虎”这样的名号。 所以在“广东十虎”当中排名第一的,我们只会选黄飞鸿的老爸黄麒英,儿子都这么强了,当老爹的不是更无敌...