mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
25 lines
452 B
Python
25 lines
452 B
Python
|
# Tribonacci sequence using Dynamic Programming
|
||
|
|
||
|
|
||
|
def tribonacci(num: int) -> list[int]:
|
||
|
"""
|
||
|
Given a number, return first n Tribonacci Numbers.
|
||
|
>>> tribonacci(5)
|
||
|
[0, 0, 1, 1, 2]
|
||
|
>>> tribonacci(8)
|
||
|
[0, 0, 1, 1, 2, 4, 7, 13]
|
||
|
"""
|
||
|
dp = [0] * num
|
||
|
dp[2] = 1
|
||
|
|
||
|
for i in range(3, num):
|
||
|
dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3]
|
||
|
|
||
|
return dp
|
||
|
|
||
|
|
||
|
if __name__ == "__main__":
|
||
|
import doctest
|
||
|
|
||
|
doctest.testmod()
|