Java 递归

Java 递归

递归是进行函数调用本身的技术。这种技术提供了一种将复杂问题分解为更容易解决的简单问题的方法。

递归可能有点难以理解。弄清楚它是如何工作的最好方法就是用它进行实验。


递归实例

将两个数字相加很容易,但将一系列数字相加则更为复杂。在下面的示例中,递归用于将一系列数字相加,方法是将其分解为两个数字相加的简单任务:

实例

使用递归将所有数字相加至 10。

  1. public class Main {
  2. public static void main(String[] args) {
  3. int result = sum(10);
  4. System.out.println(result);
  5. }
  6. public static int sum(int k) {
  7. if (k > 0) {
  8. return k + sum(k - 1);
  9. } else {
  10. return 0;
  11. }
  12. }
  13. }
实例解释

调用 sum() 函数时,它会将参数 k 添加到比 k 小的所有数字的和中,并返回结果。当 k 变为 0 时,函数只返回 0。运行时,程序遵循以下步骤:

  1. 10 + sum(9)
  2. 10 + ( 9 + sum(8) )
  3. 10 + ( 9 + ( 8 + sum(7) ) )
  4. ...
  5. 10 + 9 + 8 + 7 + 6 + 5 + 4 + 3 + 2 + 1 + sum(0)
  6. 10 + 9 + 8 + 7 + 6 + 5 + 4 + 3 + 2 + 1 + 0

处理条件

正如循环会遇到无限循环的问题一样,递归函数也会遇到无限递归的问题。无限递归是指函数从不停止调用自身。每个递归函数都应该有一个停止条件,即函数停止调用自身的条件。在上一个示例中,停止条件是当参数 k 变为 0 时。

看到各种不同的例子有助于更好地理解这个概念。在本例中,函数在开始和结束之间添加一系列数字。此递归函数的停止条件是 end 不大于 start:

实例

使用递归将 5 到 10 之间的所有数字相加。

  1. public class Main {
  2. public static void main(String[] args) {
  3. int result = sum(5, 10);
  4. System.out.println(result);
  5. }
  6. public static int sum(int start, int end) {
  7. if (end > start) {
  8. return end + sum(start, end - 1);
  9. } else {
  10. return end;
  11. }
  12. }
  13. }