【代码随想录】刷题笔记Day40

前言

  • 终于把贪心这一章刷完了,接下来动态规划!好多题啊,争取一两周搞定!

动态规划理论基础

  • 动规做题五部曲
  • 【代码随想录】刷题笔记Day40_第1张图片

509. 斐波那契数 - 力扣(LeetCode)

  • 入门简单,状态转移方程:dp[i] = dp[i - 1] + dp[i - 2];
  • class Solution {
    public:
        int fib(int N) {
            if (N <= 1) return N;
            vector dp(N + 1);
            // 初始条件
            dp[0] = 0;
            dp[1] = 1;
            // 遍历顺序
            for (int i = 2; i <= N; i++) {
                // 状态转移
                dp[i] = dp[i - 1] + dp[i - 2];
            }
            return dp[N];
        }
    };

 70. 爬楼梯 - 力扣(LeetCode)

  • 爬n阶可以由(n-1阶爬1阶 n-2阶爬2阶)组成,所以方式 dp[i] = dp[i - 1] + dp[i - 2]
  • class Solution {
    public:
        int climbStairs(int n) {
            if(n == 1) return 1;  // dp[1] = 1
            int dp[46];
            dp[2] = 2;
            dp[3] = 3;
            for(int i = 4; i <= n; i++){
                dp[i] = dp[i - 1] + dp[i - 2];
            }
            return dp[n];
        }
    };

 746. 使用最小花费爬楼梯 - 力扣(LeetCode)

  • 有花费的爬楼梯,dp[i]表示爬到第i阶所需要的最小花费,转移条件dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);,初始化dp[0]和dp[1]为1
  • 【代码随想录】刷题笔记Day40_第2张图片
  • class Solution {
    public:
        int minCostClimbingStairs(vector& cost) {
            int dp[1001];
            dp[0] = 0;
            dp[1] = 0;
            for(int i = 2; i <= cost.size(); i++){
                dp[i] = min(dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]);
            }
            return dp[cost.size()];
        }
    };

后言

  •  上午先写这么多,上课实在效率太低,感觉动规的分析还挺好玩(数学归纳?)

你可能感兴趣的:(代码随想录刷题笔记,笔记,leetcode,算法,职场和发展,数据结构)