week4刷题

week4刷题_第1张图片

 题解:

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;
    }
};

week4刷题_第2张图片

题解:

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;
    }
};

 

你可能感兴趣的:(java,开发语言)