algorithm-in-python/math/fibonacci/fibonacci.py

42 lines
1.2 KiB
Python
Raw Permalink Normal View History

#coding: utf-8
''' mbinary
#######################################################################
# File : fibonacci.py
# Author: mbinary
# Mail: zhuheqin1@gmail.com
# Blog: https://mbinary.github.io
# Github: https://github.com/mbinary
# Created Time: 2019-02-03 19:10
# Description: use matrix and fast pow to calculate big numbr fibonacci value.
#######################################################################
'''
2020-04-15 12:28:20 +08:00
def fib(n):
2020-04-15 12:28:20 +08:00
"""Calculates the nth Fibonacci number"""
mat, p = (1, 1, 1, 0), n-2
if n <= 0: # for negative fib item, use f(n) = f(n+2)-f(n-1) to calculate
mat = (0, 1, 1, -1), 2-n
li = matrix_pow((0, 1, 1, -1), 1-n)
return li[0]+li[1]
def matrix_pow(mat, n):
ans = (1, 0, 0, 1) # element matrix
while n > 0:
if n % 2 == 1:
ans = matrix_mul(ans, mat)
n >>= 1
mat = matrix_mul(mat, mat)
return ans
2020-04-15 12:28:20 +08:00
def matrix_mul(a, b):
'''a,b are four-item tuple, represent matrix [[a[0],a[1]],[a[2],a[3]]]'''
2020-04-15 12:28:20 +08:00
return a[0]*b[0]+a[1]*b[2], a[0]*b[1]+a[1]*b[3], a[2]*b[0]+a[3]*b[2], a[2]*b[1]+a[3]*b[3]
2020-04-15 12:28:20 +08:00
if __name__ == '__main__':
for i in range(-5, 5):
print(i, fib(i))