递归(英语:Recursion),又译为递回,在数学与计算机科学中,是指在函数的定义中使用函数自身的方法。递归一词还较常用于描述以自相似方法重复事物的过程。例如,当两面镜子相互之间近似平行时,镜中嵌套的图像是以无限递归的形式出现的。也可以理解为自我复制的过程。
一.求阶乘
有数学表达式
n ! = n ⋅ ( n − 1 ) ⋅ ( n − 2 ) ⋅ ⋅ ⋅ 2 ⋅ 1
可以很容易写出递归的代码
public static int fact(int n) {
if (n <= 1)
return 1;
return n * fact(n - 1);
}
二. 求斐波那契数列
可以很容易写出递归的代码
public static int fib(int n) { if (n == 1 || n == 2) { return 1; } return fib(n - 1) + fib(n - 2); }
三. 数组求和 这也可以看成一个递归问题,要求数组中n个数的和可以转化为开始第一个数与剩余n-1个数的和的和。 基准情况:开始的那个数为数组的最后一个数,则直接返回这个数。 递归:开始第一个数与剩余n-1个数的和的和。
/**
四. 反转字符串 递归分析:将问题分解为反转最后一个字符与剩余的字符串。 基准情况:只剩下一个字符是,直接返回字符 递归:求解最后一个字符与剩余的字符串
/**
五. 最大公约数 这是一个数学问题,利用辗转相除法。 辗转相除法基于如下原理:两个整数的最大公约数等于其中较小的数和两数相除余数的最大公约数。例如,252和105的最大公约数是21(252 = 21 × 12; 105 = 21 × 5);因为 252 − 105 = 21 × (12 − 5) = 147 ,所以147和105的最大公约数也是21。在这个过程中,较大的数缩小了,所以继续进行同样的计算可以不断缩小这两个数直至其中一个变成零。这时,所剩下的还没有变成零的数就是两数的最大公约数。 基准情况:两个数其中一个变成零。 递归:求较小的数和较大的数与较小的数的余数的最大公约数
/**
六. 插入排序递归法
/**
七. 汉诺塔问题
public static void printHanoTower(int n,String from,String to, String help){ if(n==1){ System.out.println("move "+n+" from "+from+" to " + to); return; } printHanoTower(n-1,from,help,to); System.out.println("move "+n+" from "+ from +" to "+to); printHanoTower(n-1,help,to, from); }