[ 矩 阵 乘 法 ] 裴 波 拉 契 数 列 I I [矩阵乘法]裴波拉契数列II [矩阵乘法]裴波拉契数列II
Description
形如 1 1 2 3 5 8 13 21 34 55 89 144…的数列,求裴波拉契数列的第n项。
Input
n (1< n <2^31)
Output
一个数为裴波拉契数列的第n项mod 10000;
Sample Input
123456789
Sample Output
4514
题目解析
首先看题面,是斐波那契数列。首先想到递归,但考虑到N的值比较大,就想办法将时间复杂度降到 O ( l o g N ) O(logN) O(logN)以达到目的。
那么怎么将时间复杂度降下来呢?
我们将斐波那契数列的第 n n n项定义为 f ( n ) f(n) f(n),然后考虑用矩阵乘法进行一个时间复杂度的优化
那么我们考虑矩阵 ⊏ f [ n − 2 ] , f [ n − 1 ] ⊐ \sqsubset f[n - 2] , f[n - 1]\sqsupset ⊏f[n−2],f[n−1]⊐并利用斐波那契数列的递推关系来得到式子 ⊏ f