迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

Java 中的递归斐波那契数列

作者:迹忆客 最近更新:2023/09/28 浏览次数:

斐波那契数列

由从 0 和 1 开始的最后两个数字相加形成的序列。如果要查找第 n 个元素,则可以通过(n-1)和(n-2)项相加来找到该数字,其中 n 必须大于 0。


递归

递归是一个过程,其中相同的确定性函数或过程多次调用其自身,直到遇到终止条件为止。如果不指定终止条件,则该方法将进入无限循环状态。


Java 中的递归斐波那契数列

在下面给出的代码中,main() 方法调用在该类中定义的静态函数 getFibonacciNumberAt()。该函数采用一个定义数字的参数,我们要在其中评估斐波那契数。该函数具有一次主要检查,当它符合所需条件时将返回 0 或 1。否则,该函数将通过减少传递给它的参数来再次调用自身。

package recursiveFibonacci;

public class RecursiveFibonacciSequence {
    public static void main(String[] args) {
        int fibonacciNumber = getFibonacciNumberAt(6);
        System.out.println(fibonacciNumber);
    }

    public static int getFibonacciNumberAt(int n) {
        if (n == 0)
            return 0;
        else if (n == 1)
            return 1;
        else
            return getFibonacciNumberAt(n - 1) + getFibonacciNumberAt(n - 2);
    }
}

输出:

8

详细的评估如下所示:

getFibonacciNumberAt(6) = getFibonacciNumberAt(5) + getFibonacciNumberAt(4); //5+3=8
getFibonacciNumberAt(5) = getFibonacciNumberAt(4) + getFibonacciNumberAt(3); //3+2=5
getFibonacciNumberAt(4) = getFibonacciNumberAt(3) + getFibonacciNumberAt(2); //2+1=3
getFibonacciNumberAt(3) = getFibonacciNumberAt(2) + getFibonacciNumberAt(1); //1+1=2
getFibonacciNumberAt(2) = getFibonacciNumberAt(1) + getFibonacciNumberAt(0); //1+0=1
If, getFibonacciNumberAt(1) = 1;
And getFibonacciNumberAt(0) = 0;

我们可以修改上述程序,以打印出所需数量的序列。

package recursiveFibonacci;

public class RecursiveFibonacci {
    public static void main(String[] args) {
        int maxCount = 10;
        for (int i = 0; i <= maxCount; i++) {
            int fibonacciNumber = printFibonacci(i);
            System.out.print(" " + fibonacciNumber);
        }
    }

    public static int printFibonacci(int n) {
        if (n == 0)
            return 0;
        else if (n == 1)
            return 1;
        else
            return printFibonacci(n - 1) + printFibonacci(n - 2);
    }
}

输出:

0 1 1 2 3 5 8 13 21 34 55

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

检查是否安装了 Java

发布时间:2023/09/29 浏览次数:186 分类:Java

本文按照步骤检查 Java 是否安装在不同的操作系统中。本文教我们检查机器上是否安装了 Java。一些软件和应用程序需要 Java,要检查我们的设备是否支持它,我们需要按照以下步骤操作。

检查 Java 版本

发布时间:2023/09/29 浏览次数:194 分类:Java

本文介绍了检查已安装 Java 版本的方法。Java 是一种用于创建软件应用程序的编程语言。要检查本地系统中安装的 Java 版本,你可以使用一些将结果显示到控制台的命令。

检查 Linux 中的 Java 版本

发布时间:2023/09/29 浏览次数:150 分类:Java

本文讨论了在 Linux 机器上检查 Java 版本的方法。要在 Linux 中检查 Java 版本,我们可以使用 version 命令、whereis 命令和文件路径。

在 Mac 中检查 Java 版本

发布时间:2023/09/29 浏览次数:180 分类:Java

Java 平台是一种安全的开发语言环境,使你能够在各种计算平台上快速构建和部署应用程序。它提供了一个不依赖底层操作系统的安全运行时环境,同时提供与本地方法和传统编程语言的

在 Java 中转义 HTML

发布时间:2023/09/29 浏览次数:153 分类:Java

本文解释了如何在 Java 中转义 HTML 字符和符号。为此,我们可以使用 Apache commons-text 和 StringEscapeUtils.escapeHtml4(str) 方法来转义 Java 中的 HTML 符号和字符。

Java 中的无穷大数

发布时间:2023/09/29 浏览次数:62 分类:Java

文章介绍了在 Java 中实现无穷大的方法。本文讨论了在 Java 中实现无穷大的方法。有几个数学场景可能需要实现无穷大的数学运算。

Java 中的幂运算

发布时间:2023/09/29 浏览次数:198 分类:Java

本篇文章主要讲的是在 Java 中如何进行幂运算。本文介绍了如何在 Java 中进行幂操作,并列举了一些示例代码来理解这个话题。

在 Java 中生成指定范围内的随机数

发布时间:2023/09/29 浏览次数:121 分类:Java

这篇文章介绍了如何在 Java 中生成指定范围内的随机数。本文介绍了如何在 Java 中生成指定范围内的随机数。有几种在 Java 中生成随机数的方法,例如 ThreadLocalRandom 类的 nextInt() 方法,Math 类的

Java 中的分数

发布时间:2023/09/29 浏览次数:157 分类:Java

本文介绍了 Java 中分数的表示。在数学上,分数是值的部分或部分。当一个物体以一定的比例被均等地分解时,所形成的值称为分数。分数分为有理数和无理数。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便