初学者第19节之递归算法
公告通知

本公众号纯属个人公益公众号!只求能帮助到各位java初学者,公众号有一系列免费资源领取,供广大java初学者自学!也有微信交流群供大家学习讨论!!!大家可以多多关注!!!也可以对我们的文章可以多多留言,留下您的宝贵意见!!!

简单递归定义

什么叫递归?(先定义一个比较简单的说法,为了理解,不一定对)

递归:无限调用自身这个函数,每次调用总会改动一个关键变量,直到这个关键变量达到边界的时候,不再调用。

对刚开始接触计算机编程的人而言,这里有递归的一个简单定义:当函数直接或者间接调用自己时,则发生了递归。

递归是一种常见的解决问题的方法,寄把问题逐渐简单化。递归的基本思想就是“自己调用自己”,一个使用递归技术的方法会直接或间接的调用自己
递归构造包括两个部分:


定义递归头。什么时候不调用自身方法,如果没有头,将陷入死循环
递归体。什么时候需要调用自身方法

其实递归算法很简单,简单点就是自己调用自己的方法,有条件判断什么时候停止!

 

递归的经典示例

计算阶乘是递归程序设计的一个经典示例。计算某个数的阶乘就是用那个数去乘包括 1 在内的所有比它小的数。例如,factorial(5) 等价于5*4*3*2*1,而 factorial(3) 等价于 3*2*1。

阶乘的一个有趣特性是,某个数的阶乘等于起始数(starting number)乘以比它小一的数的阶乘。例如,factorial(5) 与 5 * factorial(4) 相同。您很可能会像这样编写阶乘函数:




作业

下面给大家出一个练习题,还是上节的“99乘法表”用递归实现

答案可以在公众号回复“递归99乘法表”



扫码关注 ∣有捣乱者绕道


长按,识别二维码,加关注

注:本公众号纯属个人公益公众号!

不存在任何培训机构招生信息!!


阅读更多
个人分类: java初学者全集
想对作者说点什么? 我来说一句

SQL初学者指南(第二版)配套光盘

2010年10月28日 14.19MB 下载

初学函数递归,c里用到的

2010年11月25日 274B 下载

没有更多推荐了,返回首页

不良信息举报

初学者第19节之递归算法

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭