How to calculate tribonacci number for very large n ( say 10^14 ) in best complexity. Tribonacci numbers are defined as F(n)=F(n-1)+F(n-2)+F(n-3)
with F0=1, F1=2, F2=4
.
Or recurrence defined as
F(n)=aF(n-1)+bF(n-2)+cF(n-3)
with F0=1, F1=2, F2=4
.
I want to Calculate nth term in log(n) just like nth Fibonacci number.
How can I generate the Base Matrix for using matrix exponentiation to calulate the nth term?
Previously I was trying to implement it using DP but as we cannot take array of such large size its not working fine. Similarly Recursion didn't work here due to stack overflow for very large numbers of order of 10^14.
A Dynamic programming solution does NOT require 10^14 elements array. It only requires 3.
Note that each step is only using previous 3 elements, so for
F(1000)
, you really do not needF(5)
.You can simply override elements that are no longer needed, and regard them as a new number.
The
%
operator is your friend for this purpose.The best asymptotic complexity for tribonacci numbers will be using a matrix exponentiation method like the one for Fibonacci numbers. Specifically, written correctly, this is O(log n) integer operations, rather than O(n) (like the dynamic programming method) or O(3n) (like the naive solution).
The matrix of interest is
and the nth tribonacci number is in the upper left corner of Mn. The matrix exponentiation must be computed by squaring to achieve log(n) complexity.
(for
F(n+3) = a F(n+2) + b F(n+1) + c F(n)
, the matrix is:and the result is {Fn+2,Fn+1,Fn} = Mn {F2,F1,F0}, also see here.)