2016-09-26 18:28:43 +08:00
|
|
|
"""
|
|
|
|
This is a pure Python implementation of Dynamic Programming solution to the fibonacci sequence problem.
|
|
|
|
"""
|
2016-09-26 18:26:23 +08:00
|
|
|
|
2016-09-26 18:38:40 +08:00
|
|
|
|
|
|
|
class Fibonacci:
|
2016-09-26 18:26:23 +08:00
|
|
|
def __init__(self, N=None):
|
2017-04-12 06:10:52 +08:00
|
|
|
self.fib_array = []
|
2016-09-26 18:26:23 +08:00
|
|
|
if N:
|
2016-09-26 18:38:40 +08:00
|
|
|
N = int(N)
|
2017-04-12 06:10:52 +08:00
|
|
|
self.fib_array.append(0)
|
|
|
|
self.fib_array.append(1)
|
2016-09-26 18:26:23 +08:00
|
|
|
for i in range(2, N + 1):
|
2017-04-12 06:10:52 +08:00
|
|
|
self.fib_array.append(self.fib_array[i - 1] + self.fib_array[i - 2])
|
2017-04-12 21:45:56 +08:00
|
|
|
elif N == 0:
|
2017-04-12 06:10:52 +08:00
|
|
|
self.fib_array.append(0)
|
2019-10-10 03:20:19 +08:00
|
|
|
print(self.fib_array)
|
2016-09-26 18:26:23 +08:00
|
|
|
|
|
|
|
def get(self, sequence_no=None):
|
2019-10-10 03:20:19 +08:00
|
|
|
"""
|
|
|
|
>>> Fibonacci(5).get(3)
|
|
|
|
[0, 1, 1, 2, 3, 5]
|
|
|
|
[0, 1, 1, 2]
|
|
|
|
>>> Fibonacci(5).get(6)
|
|
|
|
[0, 1, 1, 2, 3, 5]
|
|
|
|
Out of bound.
|
|
|
|
>>> Fibonacci(5).get(-1)
|
|
|
|
[0, 1, 1, 2, 3, 5]
|
|
|
|
[]
|
|
|
|
"""
|
2017-04-12 21:45:56 +08:00
|
|
|
if sequence_no != None:
|
2016-09-26 18:26:23 +08:00
|
|
|
if sequence_no < len(self.fib_array):
|
2019-10-05 13:14:13 +08:00
|
|
|
return print(self.fib_array[: sequence_no + 1])
|
2016-09-26 18:26:23 +08:00
|
|
|
else:
|
|
|
|
print("Out of bound.")
|
|
|
|
else:
|
2017-04-12 06:10:52 +08:00
|
|
|
print("Please specify a value")
|
2016-09-26 18:26:23 +08:00
|
|
|
|
|
|
|
|
2019-10-05 13:14:13 +08:00
|
|
|
if __name__ == "__main__":
|
2016-09-26 18:26:23 +08:00
|
|
|
print("\n********* Fibonacci Series Using Dynamic Programming ************\n")
|
|
|
|
print("\n Enter the upper limit for the fibonacci sequence: ", end="")
|
|
|
|
try:
|
2019-08-19 21:37:49 +08:00
|
|
|
N = int(input().strip())
|
2016-09-26 18:26:23 +08:00
|
|
|
fib = Fibonacci(N)
|
|
|
|
print(
|
2019-08-19 21:37:49 +08:00
|
|
|
"\n********* Enter different values to get the corresponding fibonacci "
|
2019-10-05 13:14:13 +08:00
|
|
|
"sequence, enter any negative number to exit. ************\n"
|
|
|
|
)
|
2016-09-26 18:26:23 +08:00
|
|
|
while True:
|
2016-09-26 18:38:40 +08:00
|
|
|
try:
|
2019-08-19 21:37:49 +08:00
|
|
|
i = int(input("Enter value: ").strip())
|
2016-09-26 18:38:40 +08:00
|
|
|
if i < 0:
|
|
|
|
print("\n********* Good Bye!! ************\n")
|
|
|
|
break
|
|
|
|
fib.get(i)
|
|
|
|
except NameError:
|
|
|
|
print("\nInvalid input, please try again.")
|
2016-09-26 18:26:23 +08:00
|
|
|
except NameError:
|
|
|
|
print("\n********* Invalid input, good bye!! ************\n")
|
2019-10-23 01:13:48 +08:00
|
|
|
|
2019-10-10 03:20:19 +08:00
|
|
|
import doctest
|
|
|
|
|
|
|
|
doctest.testmod()
|