什么是递归?
递归在程序语言中简单理解就是:方法自己调用自己。
递归和循环非常像,循环都可以写成递归。递归未必能写成循环。
有了循环,为什么还需要递归呢?
在某些情况下,使用递归会比循环简单很多很多。(斐波那契数列,汉诺塔)。
使用递归我们需要 注意什么?
我们需要记住,想要用递归必须知道两个条件:
- 递归的出口(终止递归的条件)
- 递归表达式(规律)
技巧:在 递归中常常将问题切割成两个部分(1和整体的思想),这能够让我们快速找到递归的表达式。
案例:
求和:
使用for遍历的方式进行求和(1到100的求和)
int sum = 0;
for (int i = 1; i <= 100; i++) {
sum = sum + i;
}
使用递归求和:(需要知道两个必要条件:递归出口,递归表达式)
递归出口:if(n=1) return 1;
public static void main(String[] args) {
sum(100);
}
/**
*
* @param n 要加到的数字,比如题目的100
* @return
*/
public static int sum(int n) {
if (n == 1) {
return 1;
} else {
return sum(n - 1) + n;
}
}
案例二:数组内部的最大值
使用for循环:
int[] arrays = {2, 3, 4, 5, 1, 5, 2, 9, 5, 6, 8, 3, 2};
//将数组的第一个假设是最大值
int max = arrays[0];
for (int i = 1; i < arrays.length; i++) {
if (arrays[i] > max) {
max = arrays[i];
}
}
使用递归:
递归出口:如果数组中只有一个元素就是他的出口了。
public static void main(String[] args) {
int[] arrays = {2, 3, 4, 5, 1, 5, 2, 9, 5, 6, 8, 3, 1};
findMax(arrays, 0, arrays.length - 1);
}
/**
* 递归,找出数组最大的值
* @param arrays 数组
* @param L 左边界,第一个数
* @param R 右边界,数组的长度
* @return
*/
public static int findMax(int[] arrays, int L, int R) {
//如果该数组只有一个数,那么最大的就是该数组第一个值了
if (L == R) {
return arrays[L];
} else {
int a = arrays[L];
int b = findMax(arrays, L + 1, R);//找出整体的最大值
if (a > b) {
return a;
} else {
return b;
}
}
}
案例:冒泡排序递归写法
public static void main(String[] args) {
int[] arrays = {2, 3, 4, 5, 1, 5, 2, 9, 5, 6, 8, 3, 1};
bubbleSort(arrays, 0, arrays.length - 1);
System.out.println(arrays);
}
public static void bubbleSort(int[] arrays, int L, int R) {
int temp;
//如果只有一个元素了,那什么都不用干
if (L == R) ;
else {
for (int i = L; i < R; i++) {
if (arrays[i] > arrays[i + 1]) {
temp = arrays[i];
arrays[i] = arrays[i + 1];
arrays[i + 1] = temp;
}
}
//第一趟排序后已经将最大值放到数组最后面了
//接下来是排序"整体"的数据了
bubbleSort(arrays, L, R - 1);
}
}
案例:斐波那契数列(前两项之和等于第三项)
菲波那切数列长这个样子:{1 1 2 3 5 8 13 21 34 55….. n }
递归出口:if(n==1) retrun 1 if(n==2) return 2
递归表达式:Z = (n-2) + (n-1)
public static void main(String[] args) {
int[] arrays = {1, 1, 2, 3, 5, 8, 13, 21};
//bubbleSort(arrays, 0, arrays.length - 1);
int fibonacci = fibonacci(10);
System.out.println(fibonacci);
}
public static int fibonacci(int n) {
if (n == 1) {
return 1;
} else if (n == 2) {
return 1;
} else {
return (fibonacci(n - 1) + fibonacci(n - 2));
}
}