递推算法是经常使用的算法思想,在数学计算等方面有着普遍的应用。递推算法适合有着明显公式的规律场合。算法
递推算法是一种理性思惟模式的表明,其根据已有的数据和关系,逐步推导而获得结果。递推算法的执行过程以下:spa
递推算法每每须要用户知道答案和问题之间的逻辑关系。在许多数学问题中,都有着明确的计算公式能够遵循,所以每每能够采用递推算法来实现。code
递推算法是基本的算法思想,经常使用于数学相关的场合。虾米那经过一个简单的数学例子来分析递推算法的应用。递归
数学里面的斐波那契数列即是一个使用递推算法的经典例子以下:事件
若是一对两个月大的兔子之后每个月均可以生一对小兔子,而一对新生的兔子出生两个月后才能够生小兔子。也就是说,1月份出生,三月份才可产仔。那么假定一年内没有发生兔子死亡事件,那么1年后共有多少对兔子呢?ci
先来分析一下兔子产仔问题,逐月分析每个月兔子对数。数学
从上述内容能够看出,从第3个月开始,每月的兔子总对数等于前两个月兔子数的总和。相应的计算公式(Fn=F(n-1)+F(n-2)),这里的n是第n个月,这里初始第1个月的兔子数为F1=1,F2=1。实例以下:class
public static int fibonacci(int n){ int t1,t2; if (n == 1 || n == 2){ return 1; }else{ t1 = fibonacci(n-1);//递归调用 t2 = fibonacci(n-2);//递归调用 int num = t1 + t2; return num; } }
根据上述通用的兔子产仔问题算法,能够求解任意该类问题。下面给出完整的兔子产仔问题求解代码im
public class mian1 { /** * 若是一对两个月大的兔子之后每个月均可以生一对小兔子,而一对新生的兔子出生两个月后才能够生小兔子。 * 也就是说1月份出生,三月份才可产仔。那么假定一年内没有发生兔子死亡事件,那么1年后共有多少对兔子呢? */ public static int fibonacci(int n){ int t1,t2; if (n == 1 || n == 2){ return 1; }else{ t1 = fibonacci(n-1);//递归调用 t2 = fibonacci(n-2);//递归调用 int num = t1 + t2; return num; } } public static void main(String[] args) { System.out.print("请先输入月份:"); Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); int num = fibonacci(n); System.out.println("通过"+n+"月的时间,共繁殖了"+num+"对兔子!"); } }
效果以下:next
请先输入月份:12 通过12月的时间,共繁殖了144对兔子!