代码随想录第36天|动态规划

62. 不同路径


补充: 对二维数组的操作

  1. dp[j][i] 表示到 j,i 有多少种路径
  2. 递推公式: dp[j][i] = dp[j - 1][i] + dp[j][i - 1]
  3. 初始化: dp[0][i] 和 dp[j][0] 都只有1种情况
  4. 遍历顺序: 由于dp[j][i] 由 上和左的元素推导, 所以采用从左到右、从上到下的遍历顺序
cpp 复制代码
class Solution {
public:
    void uniquePaths(int m, int n) {
        vector<vector<int>> dp(m, vector<int>(n, 0));
        //初始化
        for (int i = 0; i < dp[0].size(); i++) dp[0][i] = 1;
        for (int i = 0; i < dp.size(); i++) dp[i][0] = 1;
        //递推公式
        for (int j = 1; j < m; j++) {
            for (int i = 1; i < n; i++) {
                dp[j][i] = dp[j][i - 1] + dp[j - 1][i];
            }
        }
        //输出dp[j][i]
        for (int j = 0; j < dp.size(); j++) {
            for (int i = 0; i < dp[i].size(); i++) {
                cout << dp[j][i] << " ";
            }
            cout << endl;
        }
        return dp[m - 1][n - 1];                  
    }
};

63. 不同路径 II



参考

  1. dp[j][i] 表示到(j, i) 后的路径数
  2. 递推公式
  3. 初始化 dp[0][i] 和 dp[j][0] 为 1 ,当遇到障碍物后变 0
  4. 遍历顺序同上
cpp 复制代码
class Solution {
public:
    int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
        int n = obstacleGrid[0].size();
        int m = obstacleGrid.size();        
        vector<vector<int>> dp = vector<vector<int>>(m, vector<int>(n, 0));
        for (int i = 0; i < n; i++) {
            if (obstacleGrid[0][i] == 1) break;
            dp[0][i] = 1;
        }
        for (int j = 0; j < m; j++) {
            if (obstacleGrid[j][0] == 1) break;
            dp[j][0] = 1;
        }

        for (int j = 1; j < m; j++) {
            for (int i = 1; i < n; i++) {
                if (obstacleGrid[j][i] == 1) {//该点有障碍
                    dp[j][i] = 0;                    
                } else {
                    dp[j][i] = dp[j][i - 1] + dp[j - 1][i];
                }              
            }
        }
        return dp[m - 1][n - 1];
    }
};

343. 整数拆分

  1. dp[i] : 整数i的最大乘积
  2. 递推公式
  3. 初始化
  4. 遍历顺序

未弄懂


96. 不同的二叉搜索树

相关推荐
lingchen190610 小时前
MATLAB图形绘制基础(一)二维图形
开发语言·算法·matlab
hlpinghcg10 小时前
(全闭环)FUNC_FullCloseLoop
算法·电机·电机控制
朝新_11 小时前
【EE初阶】JVM
java·开发语言·网络·jvm·笔记·算法·javaee
x70x8011 小时前
git仓库基本使用
git·算法·编程
仰泳的熊猫11 小时前
LeetCode:773. 滑动谜题
数据结构·c++·算法·leetcode
夏鹏今天学习了吗11 小时前
【LeetCode热题100(50/100)】岛屿数量
算法·leetcode·职场和发展
墨染点香11 小时前
LeetCode 刷题【134. 加油站】
算法·leetcode·职场和发展
yi碗汤园12 小时前
【一文了解】八大排序-冒泡排序、选择排序
开发语言·前端·算法·unity·c#·1024程序员节
二倍速播放12 小时前
贪心算法 with Gemini
算法·贪心算法
oliveira-time13 小时前
整数划分问题
算法