递归就是方法自身调用自身的行为,注意要写好递归头,也就是什么时候退出递归,
避免出现死循环。
实例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的阶乘
}
}
关于递归计算阶乘,递归内存分析结构图:
先放长线,最后收线,然后把鱼拉上岸。