电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本
换一换
首页 金锄头文库 > 资源分类 > DOCX文档下载
分享到微信 分享到微博 分享到QQ空间

为什么你学不会递归?告别递归谈谈我的一些经验.docx

  • 资源ID:141385158       资源大小:171.20KB        全文页数:13页
  • 资源格式: DOCX        下载积分:10金贝
快捷下载 游客一键下载
账号登录下载
微信登录下载
三方登录下载: 微信开放平台登录   支付宝登录   QQ登录  
二维码
微信扫一扫登录
下载资源需要10金贝
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
支付方式: 支付宝    微信支付   
验证码:   换一换

 
账号:
密码:
验证码:   换一换
  忘记密码?
    
1、金锄头文库是“C2C”交易模式,即卖家上传的文档直接由买家下载,本站只是中间服务平台,本站所有文档下载所得的收益全部归上传人(卖家)所有,作为网络服务商,若您的权利被侵害请及时联系右侧客服;
2、如你看到网页展示的文档有jinchutou.com水印,是因预览和防盗链等技术需要对部份页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有jinchutou.com水印标识,下载后原文更清晰;
3、所有的PPT和DOC文档都被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;下载前须认真查看,确认无误后再购买;
4、文档大部份都是可以预览的,金锄头文库作为内容存储提供商,无法对各卖家所售文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;
5、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据;
6、如果您还有什么不清楚的或需要我们协助,可以点击右侧栏的客服。
下载须知 | 常见问题汇总

为什么你学不会递归?告别递归谈谈我的一些经验.docx

为什么你学不会递归?告别递归,谈谈我的一些经验可能很多人在大一的时候,就已经接触了递归了,不过,我敢保证很多人初学者刚开始接触递归的时候,是一脸懵逼的,我当初也是,给我的感觉就是,递归太神奇了!可能也有一大部分人知道递归,也能看的懂递归,但在实际做题过程中,却不知道怎么使用,有时候还容易被递归给搞晕。也有好几个人来问我有没有快速掌握递归的捷径啊。说实话,哪来那么多捷径啊,不过,我还是想写一篇文章,谈谈我的一些经验,或许,能够给你带来一些帮助。为了兼顾初学者,我会从最简单的题讲起!递归的三大要素第一要素:明确你这个函数想要干什么对于递归,我觉得很重要的一个事就是,这个函数的功能是什么,他要完成什么样的一件事,而这个,是完全由你自己来定义的。也就是说,我们先不管函数里面的代码什么,而是要先明白,你这个函数是要用来干什么。例如,我定义了一个函数1/算n的阶乘(假设n不为0)2intf(intn)34/算n的阶乘(假设n不为0)2intf(intn)34这个函数的功能是算 n 的阶乘。好了,我们已经定义了一个函数,并且定义了它的功能是什么,接下来我们看第二要素。第二要素:寻找递归结束条件所谓递归,就是会在函数内部代码中,调用这个函数本身,所以,我们必须要找出递归的结束条件,不然的话,会一直调用自己,进入无底洞。也就是说,我们需要找出当参数为啥时,递归结束,之后直接把结果返回,请注意,这个时候我们必须能根据这个参数的值,能够直接知道函数的结果是什么。例如,上面那个例子,当 n = 1 时,那你应该能够直接知道 f(n) 是啥吧?此时,f(1) = 1。完善我们函数内部的代码,把第二要素加进代码里面,如下1/算n的阶乘(假设n不为0)2intf(intn)3if(n=1)4return1;56/算n的阶乘(假设n不为0)2intf(intn)3if(n=1)4return1;56有人可能会说,当 n = 2 时,那我们可以直接知道 f(n) 等于多少啊,那我可以把 n = 2 作为递归的结束条件吗?当然可以,只要你觉得参数是什么时,你能够直接知道函数的结果,那么你就可以把这个参数作为结束的条件,所以下面这段代码也是可以的。1/算n的阶乘(假设n>=2)2intf(intn)3if(n=2)4return2;56/算n的阶乘(假设n>=2)2intf(intn)3if(n=2)4return2;56注意我代码里面写的注释,假设 n >= 2,因为如果 n = 1时,会被漏掉,当 n <= 2时,f(n) = n,所以为了更加严谨,我们可以写成这样:1/算n的阶乘(假设n不为0)2intf(intn)3if(n<=2)4returnn;56/算n的阶乘(假设n不为0)2intf(intn)3if(n<=2)4returnn;56第三要素:找出函数的等价关系式第三要素就是,我们要不断缩小参数的范围,缩小之后,我们可以通过一些辅助的变量或者操作,使原函数的结果不变。例如,f(n) 这个范围比较大,我们可以让 f(n) = n * f(n-1)。这样,范围就由 n 变成了 n-1 了,范围变小了,并且为了原函数f(n) 不变,我们需要让 f(n-1) 乘以 n。说白了,就是要找到原函数的一个等价关系式,f(n) 的等价关系式为 n * f(n-1),即f(n) = n * f(n-1)。这个等价关系式的寻找,可以说是最难的一步了,如果你不大懂也没关系,因为你不是天才,你还需要多接触几道题,我会在接下来的文章中,找 10 道递归题,让你慢慢熟悉起来。找出了这个等价,继续完善我们的代码,我们把这个等价式写进函数里。如下:1/算n的阶乘(假设n不为0)2intf(intn)3if(n<=2)4returnn;56/把f(n)的等价操作写进去7returnf(n-1)*n;8/算n的阶乘(假设n不为0)2intf(intn)3if(n<=2)4returnn;56/把f(n)的等价操作写进去7returnf(n-1)*n;8至此,递归三要素已经都写进代码里了,所以这个 f(n) 功能的内部代码我们已经写好了。这就是递归最重要的三要素,每次做递归的时候,你就强迫自己试着去寻找这三个要素。还是不懂?没关系,我再按照这个模式讲一些题。有些有点小基础的可能觉得我写的太简单了,没耐心看?少侠,请继续看,我下面还会讲如何优化递归。当然,大佬请随意,可以直接拉动最下面留言给我一些建议,万分感谢!案例1:斐波那契数列斐波那契数列的是这样一个数列:1、1、2、3、5、8、13、21、34.,即第一项 f(1) = 1,第二项 f(2) = 1.,第 n 项目为 f(n) = f(n-1) + f(n-2)。求第 n 项的值是多少。1、第一递归函数功能假设 f(n) 的功能是求第 n 项的值,代码如下:1intf(intn)23intf(intn)232、找出递归结束的条件显然,当 n = 1 或者 n = 2 ,我们可以轻易着知道结果 f(1) = f(2) = 1。所以递归结束条件可以为 n <= 2。代码如下:1intf(intn)2if(n<=2)3return1;45intf(intn)2if(n<=2)3return1;45第三要素:找出函数的等价关系式题目已经把等价关系式给我们了,所以我们很容易就能够知道 f(n) = f(n-1) + f(n-2)。我说过,等价关系式是最难找的一个,而这个题目却把关系式给我们了,这也太容易,好吧,我这是为了兼顾几乎零基础的读者。所以最终代码如下:1intf(intn)2/1.先写递归结束条件3if(n<=2)4return1;56/2.接着写等价关系式7returnf(n-1)+f(n-2);8intf(intn)2/1.先写递归结束条件3if(n<=2)4return1;56/2.接着写等价关系式7returnf(n-1)+f(n-2);8搞定,是不是很简单?零基础的可能还是不大懂,没关系,之后慢慢按照这个模式练习!好吧,有大佬可能在吐槽太简单了。案例2:小青蛙跳台阶一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。1、第一递归函数功能假设 f(n) 的功能是求青蛙跳上一个n级的台阶总共有多少种跳法,代码如下:1intf(intn)23intf(intn)232、找出递归结束的条件我说了,求递归结束的条件,你直接把 n 压缩到很小很小就行了,因为 n 越小,我们就越容易直观着算出 f(n) 的多少,所以当 n = 1时,你知道 f(1) 为多少吧?够直观吧?即 f(1) = 1。代码如下:1intf(intn)2if(n=1)3return1;45intf(intn)2if(n=1)3return1;45第三要素:找出函数的等价关系式每次跳的时候,小青蛙可以跳一个台阶,也可以跳两个台阶,也就是说,每次跳的时候,小青蛙有两种跳法。第一种跳法:第一次我跳了一个台阶,那么还剩下n-1个台阶还没跳,剩下的n-1个台阶的跳法有f(n-1)种。第二种跳法:第一次跳了两个台阶,那么还剩下n-2个台阶还没,剩下的n-2个台阶的跳法有f(n-2)种。所以,小青蛙的全部跳法就是这两种跳法之和了,即 f(n) = f(n-1) + f(n-2)。至此,等价关系式就求出来了。于是写出代码:1intf(intn)2if(n=1)3return1;45ruturnf(n-1)+f(n-2);6intf(intn)2if(n=1)3return1;45ruturnf(n-1)+f(n-2);6大家觉得上面的代码对不对?答是不大对,当 n = 2 时,显然会有 f(2) = f(1) + f(0)。我们知道,f(0) = 0,按道理是递归结束,不用继续往下调用的,但我们上面的代码逻辑中,会继续调用 f(0) = f(-1) + f(-2)。这会导致无限调用,进入死循环。这也是我要和你们说的,关于递归结束条件是否够严谨问题,有很多人在使用递归的时候,由于结束条件不够严谨,导致出现死循环。也就是说,当我们在第二步找出了一个递归结束条件的时候,可以把结束条件写进代码,然后进行第三步,但是请注意,当我们第三步找出等价函数之后,还得再返回去第二步,根据第三步函数的调用关系,会不会出现一些漏掉的结束条件。就像上面,f(n-2)这个函数的调用,有可能出现 f(0) 的情况,导致死循环,所以我们把它补上。代码如下:1intf(intn)2/f(0)=0,f(1)=1,等价于n<=1时,f(n)=n。3if(n<=1)4returnn;56ruturnf(n-1)+f(n-2);7intf(intn)2/f(0)=0,f(1)=1,等价于n<=1时,f(n)=n。3if(n<=1)4returnn;56ruturnf(n-1)+f(n-2);7有人可能会说,我不知道我的结束条件有没有漏掉怎么办?别怕,多练几道就知道怎么办了。看到这里有人可能要吐槽了,这两道题也太容易了吧?能不能被这么敷衍。少侠,别走啊,下面出道难一点的。下面其实也不难了,就比上面的题目难一点点而已,特别是第三步等价的寻找。案例3:反转单链表。反转单链表。例如链表为:1->2->3->4。反转后为 4->3->2->1链表的节点定义如下:1classNode2intdate;3Nodenext;4classNode2intdate;3Nodenext;4虽然是 Java语言,但就算你没学过 Java,我觉得也是影响不大,能看懂。还是老套路,三要素一步一步来。1、定义递归函数功能假设函数 reverseList(head) 的功能是反转但链表,其中 head 表示链表的头节点。代码如下:1No

注意事项

本文(为什么你学不会递归?告别递归谈谈我的一些经验.docx)为本站会员(A***)主动上传,金锄头文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即阅读金锄头文库的“版权提示”【网址:https://www.jinchutou.com/h-59.html】,按提示上传提交保证函及证明材料,经审查核实后我们立即给予删除!

温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.