码迷,mamicode.com
首页 > 编程语言 > 详细

Java的递归算法

时间:2020-05-15 00:30:42      阅读:60      评论:0      收藏:0      [点我收藏+]

标签:java   family   函数   cto   nbsp   相同   死循环   特性   自身   

递归定义

递归的一个简单定义:当函数直接或者间接调用自己时,则发生了递归。

 

递归的基本思想就是“自己调用自己”,一个使用递归技术的方法会直接或间接的调用自己
递归构造包括两个部分:

 

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

 

其实递归算法很简单,简单点就是自己调用自己的方法,有条件判断什么时候停止!(计算顺序是从头到尾,再从尾到头)

 

递归的经典示例

 

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

 

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

技术图片

 

 

 

 

 

 

 

Java的递归算法

标签:java   family   函数   cto   nbsp   相同   死循环   特性   自身   

原文地址:https://www.cnblogs.com/canzhen/p/java_digui.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!