题解:
F(n)=F(n−1)+F(n−2)
由于斐波那契数存在递推关系,因此可以使用动态规划求解。动态规划的状态转移方程即为上述递推关系,边界条件为 F(0)F(0)F(0) 和 F(1)F(1)F(1)。
class Solution {
public:
int fib(int n) {
int MOD = 1000000007;
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)%MOD;
}
return r;
}
};
题解:
f(x)=f(x−1)+f(x−2)
表示爬到第 xxx 级台阶的方案数是爬到第 x−1x - 1x−1 级台阶的方案数和爬到第 x−2x - 2x−2 级台阶的方案数的和,即为动态规划的状态转移方程。
class Solution {
public:
int climbStairs(int n) {
int MOD = 1000000007;
int f1 = 0, f2 = 0, f3 = 1;
for (int i = 1; i <= n; ++i) {
f1 = f2;
f2 = f3;
f3 = (f1 + f2) % MOD;
}
return f3;
}
};