递归算法

递归就是方法自身调用自身的行为,注意要写好递归头,也就是什么时候退出递归,

避免出现死循环。

实例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的阶乘
	}
}

关于递归计算阶乘,递归内存分析结构图:

《递归算法》

先放长线,最后收线,然后把鱼拉上岸。

    原文作者:递归算法
    原文地址: https://blog.csdn.net/yhl_jxy/article/details/54976532
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞