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

62. 不同路径


补充: 对二维数组的操作

  1. dpji 表示到 j,i 有多少种路径
  2. 递推公式: dpji = dpj - 1i + dpji - 1
  3. 初始化: dp0i 和 dpj0 都只有1种情况
  4. 遍历顺序: 由于dpji 由 上和左的元素推导, 所以采用从左到右、从上到下的遍历顺序
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. dpji 表示到(j, i) 后的路径数
  2. 递推公式
  3. 初始化 dp0i 和 dpj0 为 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. dpi : 整数i的最大乘积
  2. 递推公式
  3. 初始化
  4. 遍历顺序

未弄懂


96. 不同的二叉搜索树

相关推荐
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树3 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050734 天前
(一)小红的数组操作
算法·编程语言