代码随想录第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. 不同的二叉搜索树

相关推荐
老赵聊算法、大模型备案1 天前
北京市生成式人工智能服务已备案信息公告(2025年12月11日)
人工智能·算法·安全·aigc
CoderYanger1 天前
C.滑动窗口-求子数组个数-越长越合法——2799. 统计完全子数组的数目
java·c语言·开发语言·数据结构·算法·leetcode·职场和发展
厕所博士1 天前
红黑树原理前置理解—— 2-3 树
算法·2-3树·红黑树原理理解前置
萌>__<新1 天前
力扣打卡每日一题————除自身外所有元素的乘积
数据结构·算法
xu_yule1 天前
算法基础—搜索(2)【记忆化搜索+BFS+01BFS+Floodfill]
数据结构·算法
s09071361 天前
Xilinx FPGA使用 FIR IP 核做匹配滤波时如何减少DSP使用量
算法·fpga开发·xilinx·ip core·fir滤波
老马啸西风1 天前
成熟企业级技术平台-10-跳板机 / 堡垒机(Bastion Host)详解
人工智能·深度学习·算法·职场和发展
子夜江寒1 天前
逻辑回归简介
算法·机器学习·逻辑回归
软件算法开发1 天前
基于ACO蚁群优化算法的多车辆含时间窗VRPTW问题求解matlab仿真
算法·matlab·aco·vrptw·蚁群优化·多车辆·时间窗
another heaven1 天前
【软考 磁盘磁道访问时间】总容量等相关案例题型
linux·网络·算法·磁盘·磁道