Menu
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

Java 教程

Java 主页 Java 简介 Java 入门 Java 语法 Java 输出 Java 注释 Java 变量 Java 数据类型 Java 类型转换 Java 运算符 Java 字符串 Java 数学 Java 布尔值 Java if...else Java switch Java while 循环 Java for 循环 Java break/continue Java 数组

Java 方法

Java 方法 Java 方法参数 Java 方法重载 Java 范围 Java 递归

Java 类

Java OOP Java 类/对象 Java 类属性 Java 类方法 Java 构造函数 Java 修饰符 Java 封装 Java 包/API Java 继承 Java 多态性 Java 内部类 Java 抽象类 Java 接口 Java 枚举 Java 用户输入 Java 日期 Java ArrayList Java LinkedList Java 列表排序 Java HashMap Java HashSet Java 迭代器 Java 包装类 Java 异常 Java 正则表达式 Java 线程 Java Lambda Java 高级排序

Java 文件处理

Java 文件 Java 创建/写入文件 Java 读取文件 Java 删除文件

Java 如何做

加两个数字 统计单词数 反转字符串 数组元素的总和 将字符串转换为数组 排序数组 查找数组平均值 查找最小元素 ArrayList 循环 HashMap 循环 循环遍历枚举 矩形的面积 偶数或奇数 正数或负数 平方根 随机数

Java 参考

Java 参考 Java 关键字 Java 字符串方法 Java 数学方法 Java 输出方法 Java 数组方法 Java ArrayList 方法 Java LinkedList 方法 Java HashMap 方法 Java Scanner 方法 Java 迭代器方法 Java 错误和异常

Java 示例

Java 示例 Java 编译器 Java 练习 Java 问答 Java 服务器 Java 证书


Java 递归


Java 递归

递归是一种函数调用自身的技术。这种技术提供了一种将复杂问题分解成简单问题的方法,从而更容易解决。

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


递归示例

将两个数字加在一起很容易,但将一系列数字加在一起则比较复杂。在以下示例中,递归用于通过将其分解成添加两个数字的简单任务来添加一系列数字。

示例

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

public class Main {
  public static void main(String[] args) {
    int result = sum(10);
    System.out.println(result);
  }
  public static int sum(int k) {
    if (k > 0) {
      return k + sum(k - 1);
    } else {
      return 0;
    }
  }
}

动手尝试 »

示例解释

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

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

由于当 k 为 0 时函数不会调用自身,因此程序在那里停止并返回结果。



停止条件

就像循环可能遇到无限循环的问题一样,递归函数也可能遇到无限递归的问题。无限递归是指函数永远不会停止调用自身。每个递归函数都应该有一个停止条件,即函数停止调用自身的条件。在前面的示例中,停止条件是当参数 k 变成 0 时。

查看各种不同的示例有助于更好地理解这个概念。在此示例中,该函数添加了从开始到结束的一系列数字。此递归函数的停止条件是当 end 不大于 start

示例

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

public class Main {
  public static void main(String[] args) {
    int result = sum(5, 10);
    System.out.println(result);
  }
  public static int sum(int start, int end) {
    if (end > start) {
      return end + sum(start, end - 1);
    } else {
      return end;
    }
  }
}

动手尝试 »

开发人员在使用递归时应格外小心,因为它很容易编写一个永远不会终止的函数,或者一个使用过多内存或处理器能力的函数。但是,如果编写正确,递归可以成为一种非常高效且数学上优雅的编程方法。




×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2024 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.