LeetCode第509题:
斐波那契数,通常用 F(n) 表示,形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:
F(0) = 0,F(1) = 1
F(n) = F(n - 1) + F(n - 2),其中 n > 1
给你 n ,请计算 F(n) 。
解法一: 递归。
public static int fib1(int n) {
if (n < 2) {
return n;
}
//递归调用
return fib(n - 1) + fib(n - 2);
}
使用递归时,时间复杂度太高,所以进行优化,使用循环。
解法二: for循环。
public static int fib(int n) {
if (n < 2) {
return n;
}
int p = 0, q = 0, r = 1;
for (int i = 2; i <= n; i++) {
p = q;
q = r;
r = p + q;
}
return r;
}