斐波纳契数是负数

sum*_*dha 2 java memoization dynamic-programming fibonacci

我使用动态编程技术编写了以下代码,但是当我运行Fibonacci为220时,我得到一个负数.这个程序有错吗?

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class Fibonaci {

    public static void main(String[] args) {
        System.out.println(" number ");
        long startTime = System.currentTimeMillis();
        HashMap<Integer, Integer> memoized = new HashMap<Integer, Integer>();
        int fib = fibonanci(220, memoized);
        System.out.println(" Total Time "
                + (System.currentTimeMillis() - startTime));

    }

    private static int fibonanci(int n, HashMap<Integer, Integer> memoized) {
        System.out.println(" n " + n);
        if (memoized.containsKey(n)) {
            return memoized.get(n);
        }

        if (n <= 0) {
            return 0;
        }
        if (n <= 2) {
            return 1;
        } else {
            int febonani = fibonanci(n - 1, memoized)
                    + fibonanci(n - 2, memoized);
            System.out.println(" febonani " + febonani);
            if (!memoized.containsKey(n)) {
                memoized.put(n, febonani);
            }
            return febonani;
        }
    }


}
Run Code Online (Sandbox Code Playgroud)

izo*_*ica 8

Fibonnacci数量增长速度非常快,在Java中的整数只适合值-2^312^31 - 1.第220个斐波纳契数是4244200115309993198876969489421897548446236915(大约2 ^ 151),这超出了这个范围,因此你得到整数溢出.

  • 我添加了确切的数字:) (2认同)

tuc*_*uxi 5

使用BigInteger代替int/Integer来避免 Ivaylo 指出的精度问题(Java 的int并且Integer不能表示超过 2 31位,long/Long不超过 2 63 的无符号整数)。BigInteger支持任意精度(仅受 JVM 可用内存量的限制)。

您的代码如下所示:

 private static BigInteger fib(int n, HashMap<Integer, BigInteger> memoized) {
    System.out.println(" n = " + n);
    if (memoized.containsKey(n)) {
        return memoized.get(n);
    } else if (n <= 0) {
        return BigInteger.ZERO;
    } else if (n <= 2) {
        return BigInteger.ONE;
    } else {
        BigInteger sum = fib(n - 1, memoized).add(fib(n - 2, memoized));
        System.out.println(" fib(" + n + ") = " + sum;
        memoized.put(n, sum);
        return sum;
    }
}  
Run Code Online (Sandbox Code Playgroud)