斐波那契数,通常用 F(n) 表示,形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:
F(0) = 0,F(1) = 1
F(n) = F(n - 1) + F(n - 2),其中 n > 1
给你 n ,请计算 F(n) 。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/fibonacci-number
刚入门递归写的基本都是斐波那契数列吧…属于较为基本的内容了,这里多提供几种方法供参考
1)递归
class Solution:
def fib(self, n: int) -> int:
if n == 0 or n == 1:
return n
else:
return self.fib(n-1) + self.fib(n-2)
2)爬楼梯
class Solution:
def fib(self, n: int) -> int:
a, b = 0,1
for i in range(n):
a, b = b, a+b
return a
3)动态规划
class Solution:
def fib(self, n: int) -> int:
res = [0,1]
if n == 0:
return 0
for j in range(2, n+1):
res += [res[j-1] + res[j-2]]
return res[-1]
这几种方法的算法思路可以说是一样的,相较于递归法,后两种方法不需要重复执行函数,效率更高