您的位置:首页 > 编程语言 > Java开发

java递归算法实例和分析

2017-02-11 00:04 127 查看
递归就是方法自身调用自身的行为,注意要写好递归头,也就是什么时候退出递归,

避免出现死循环。

实例1,通过递归打印1~100

package com.lanhuigu.base;

public class CursionTest {
private static int i = 0;
/**
* 递归打印1到100
*/
public static void testCursion01() {
i++;// 自增
if (i <= 100) {// 小于等于100时回调,否则跳出回调,避免死循环
System.out.println(i);
testCursion01();// 回调: 自身调用自身
} else {
System.out.println("Game Over!");
}
}

public static void main(String[] args) {
testCursion01();// 打印1~100
}
}


实例2,通过递归计算某个数的阶乘

package com.lanhuigu.base;

public class CursionTest {
/**
* 递归计算某个数的阶乘
*/
public static int testFactorial(int n) {
if (n == 1) {
return 1;
} else {
return n*testFactorial(n-1);
}
}

public static void main(String[] args) {
System.out.println(testFactorial(5));// 计算5的阶乘
}
}
关于递归计算阶乘,递归内存分析结构图:



先放长线,最后收线,然后把鱼拉上岸。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: