题目
斐波那契数,通常用 F(n) 表示,形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:
F(0) = 0,F(1) = 1 F(n) = F(n - 1) + F(n - 2),其中 n > 1 给你 n ,请计算 F(n) 。
示例
输入:2 输出:1 解释:F(2) = F(1) + F(0) = 1 + 0 = 1
输入:3 输出:2 解释:F(3) = F(2) + F(1) = 1 + 1 = 2
输入:4 输出:3 解释:F(4) = F(3) + F(2) = 2 + 1 = 3
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/fibonacci-number 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
实现
方法1:python
递归超时,老实算。
class Solution:
def fib(self, n: int) -> int:
if n==0: return 0
elif n==1: return 1
res=[0,1]
for i in range(2,n+1):
res.append(res[i-1]+res[i-2])
return res[-1]
方法2:java
list的取值方式和python不太一样哈,要用get(索引)
class Solution {
public int fib(int n) {
if (n==0) return 0;
if (n==1) return 1;
LinkedList<Integer> res = new LinkedList<>();
res.add(0);
res.add(1);
for (int i=2; i<=n; i++){
res.add(res.get(i-1)+res.get(i-2));
}
return res.get(n);
}
}
|