|
|
@ -0,0 +1,58 @@ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
```Python |
|
|
|
def fib(n): |
|
|
|
if n == 0 or n == 1: |
|
|
|
return n |
|
|
|
return fib(n-1) + fib(n-2) |
|
|
|
``` |
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/68c82/68c82e44ef3ce085af8c0665ebc51e1721e32b15" alt="Recursive Definition" |
|
|
|
|
|
|
|
|
|
|
|
```Python |
|
|
|
def fibHelper(n, a, b): |
|
|
|
if n == 0: |
|
|
|
return a |
|
|
|
elif n == 1: |
|
|
|
return b |
|
|
|
return fibHelper(n-1, b, a+b) |
|
|
|
|
|
|
|
|
|
|
|
def fibIterative(n): |
|
|
|
return fibHelper(n, 0, 1) |
|
|
|
``` |
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d4433/d44333a77c81ec38b9ce2f342f33b39d61e3eb59" alt="Iterative Performance" |
|
|
|
|
|
|
|
|
|
|
|
```Python |
|
|
|
def multiply(a,b): |
|
|
|
product = [0,0,0] |
|
|
|
product[0] = a[0]*b[0] + a[1]*b[1] |
|
|
|
product[1] = a[0]*b[1] + a[1]*b[2] |
|
|
|
product[2] = a[1]*b[1] + a[2]*b[2] |
|
|
|
return product |
|
|
|
|
|
|
|
|
|
|
|
def power(l, k): |
|
|
|
if k == 1: |
|
|
|
return l |
|
|
|
temp = power(l, k//2) |
|
|
|
if k%2 == 0: |
|
|
|
return multiply(temp, temp) |
|
|
|
else: |
|
|
|
return multiply(l, multiply(temp, temp)) |
|
|
|
|
|
|
|
|
|
|
|
def fibPower(n): |
|
|
|
l = [1,1,0] |
|
|
|
return power(l, n)[1] |
|
|
|
``` |
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/70e74/70e744025a00923ab0b2234d0c96723d62da1945" alt="FibPower Performance" |
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/dedec/dedecfc7e2a151a97990480f5694f29b7243e84b" alt="FibPower Performance" |