Я хочу вычислить Фибоначчи очень большого значения N, т.е. 10^6 со сложностью O (logN). Вот мой код, но он дает результат для 10^6 за 30 секунд, что очень трудоемко. Помогите мне указать на ошибку. Я должен дать результат по модулю 10^9 + 7.Матричный алгоритм возведения в степень для больших значений N
static BigInteger mod=new BigInteger("1000000007");
BigInteger fibo(long n){
BigInteger F[][] = {{BigInteger.ONE,BigInteger.ONE},{BigInteger.ONE,BigInteger.ZERO}};
if(n == 0)
return BigInteger.ZERO;
power(F, n-1);
return F[0][0].mod(mod);
}
void power(BigInteger F[][], long n) {
if(n == 0 || n == 1)
return;
BigInteger M[][] = {{BigInteger.ONE,BigInteger.ONE},{BigInteger.ONE,BigInteger.ZERO}};
power(F, n/2);
multiply(F, F);
if(n%2 != 0)
multiply(F, M);
}
void multiply(BigInteger F[][], BigInteger M[][]){
BigInteger x = (F[0][0].multiply(M[0][0])).add(F[0][1].multiply(M[1][0])) ;
BigInteger y = F[0][0].multiply(M[0][1]).add(F[0][1].multiply(M[1][1])) ;
BigInteger z = F[1][0].multiply(M[0][0]).add(F[1][1].multiply(M[1][0]));
BigInteger w = F[1][0].multiply(M[0][1]).add(F[1][1].multiply(M[1][1]));
F[0][0] = x;
F[0][1] = y;
F[1][0] = z;
F[1][1] = w;
}
Не можете ли вы сделать все с 64-битными целыми числами вместо BigIntegers? Вы все равно делаете по модулю ~ 1e9. –
Стоит отметить, что n-е число Фибоначчи имеет выражение замкнутой формы, которое можно вычислить _exactly_ для любого n, http: //en.wikipedia.org/wiki/Fibonacci_number # Closed-form_expression – Hooked