java - Java 中的超大型斐波那契数列

标签 java performance optimization biginteger fibonacci

我正在尝试快速计算大斐波那契数。这是我的代码。对于100万以上的数据来说速度太慢了,如何改进?

public static BigInteger fib(BigInteger n) {

        int k = n.intValue();
        BigInteger ans = null;

        if(k == 0) { 
            ans = new BigInteger("0");
        } else if(Math.abs(k) <= 2) {
            ans = new BigInteger("1");
        } else {
            BigInteger km1 = new BigInteger("1");
            BigInteger km2 = new BigInteger("1");

            for(int i = 3; i <= Math.abs(k); ++i) {
                ans = km1.add(km2);
                km2 = km1;
                km1 = ans;
            }
        }

       if(k<0 && k%2==0) { ans = ans.negate(); }
       return ans;
    } 

比奈效果很好。多谢你们!

最佳答案

一种方法是计算 2x2 矩阵的 (N-1)th 次方:

A = ((1, 1), (1, 0))

然后我们有

Fib(n) = A^(n-1)[0][0], for n >= 1

并且可以使用Exponentiation by squaring有效地计算矩阵A的幂

关于java - Java 中的超大型斐波那契数列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29551608/

相关文章:

Java - 在类方法中定义方法/函数/子例程

java - MongoDB 存储不正确的 DOB

javascript - 在 Javascript 中预定义数组长度

c++ - 什么属于 "Data Oriented Design"?

Java:Collections.unmodifiableXYZ(...) 在特殊情况下是否使集合对象成为享元?

java - Java 中无需内置函数即可计算 e^x

javascript - 如何使用带有 Scripts.Render 的 ASP MVC 4 bundle 的脚本延迟属性

Java:在大字典中搜索字符串的非常快速的方法

python - 查询大型 SQL Server 表时,pymssql/pyodbc 性能 (cursor.execute) 非常慢

php - 优化 LAMP 站点以提高速度的最佳实践?