原文:http://zetcode.com/java/fibonacci/

Java fibonacci 教程展示了如何计算 Java 中的 fibonacci 序列。 我们创建了几种计算斐波那契数列的算法。

斐波那契数列是一个值序列,每个值都是从 0 和 1 开始的两个前一个数字的和。因此,该序列的开头是:0、1、1、2、3、5、8、13、21、34、55、89、144 …

在本教程中,我们展示了几种用 Java 生成斐波那契数列的方法。 由于斐波那契数列是一个无限数的序列,因此我们使用BigInteger类型进行计算。

Java 斐波那契经典循环示例

第一种算法使用for循环。

FibonacciLoopEx.java

  1. package com.zetcode;
  2. import java.math.BigInteger;
  3. public class FibonacciLoopEx {
  4. public static BigInteger fibonacci(int n) {
  5. if (n <= 1) return BigInteger.valueOf(n);
  6. BigInteger previous = BigInteger.ZERO, next = BigInteger.ONE, sum;
  7. for (int i = 2; i <= n; i++) {
  8. sum = previous;
  9. previous = next;
  10. next = sum.add(previous);
  11. }
  12. return next;
  13. }
  14. public static void main(String[] args) {
  15. for (int i = 0; i <= 99; i++) {
  16. BigInteger val = fibonacci(i);
  17. System.out.println(val);
  18. }
  19. }
  20. }

该示例打印斐波那契数列的前一百个值。

Java 斐波那契递归示例

在第二个示例中,我们使用递归算法计算斐波那契数列,其中fibonacci()方法调用自身进行计算。

FibonacciRecursiveEx.java

  1. package com.zetcode;
  2. import java.math.BigInteger;
  3. public class FibonacciRecursiveEx {
  4. public static BigInteger fibonacci(int n) {
  5. if (n == 0 || n == 1) {
  6. return BigInteger.ONE;
  7. }
  8. return fibonacci(n - 2).add(fibonacci(n - 1));
  9. }
  10. public static void main(String[] args) {
  11. for (int i = 0; i < 10; i++) {
  12. System.out.println(fibonacci(i));
  13. }
  14. }
  15. }

该示例计算斐波那契序列的前十个值。

Java 斐波那契流示例

第三个示例使用 Java8 流进行计算。

FibonacciStreamEx.java

  1. package com.zetcode;
  2. import java.math.BigInteger;
  3. import java.util.List;
  4. import java.util.stream.Collectors;
  5. import java.util.stream.Stream;
  6. public class FibonacciStreamEx {
  7. public static List<BigInteger> fibonacci(int limit) {
  8. var vals = Stream.iterate(new BigInteger[] { BigInteger.ZERO, BigInteger.ONE },
  9. t -> new BigInteger[] { t[1], t[0].add(t[1]) })
  10. .limit(limit)
  11. .map(n -> n[1])
  12. .collect(Collectors.toList());
  13. return vals;
  14. }
  15. public static void main(String[] args) {
  16. System.out.println(fibonacci(100));
  17. }
  18. }

本示例计算值到一定限制。

在本教程中,我们展示了如何以三种不同的方式在 Java 中计算斐波那契数列:经典循环,递归算法和函数方式。