代码随想录训练营Day 43|力扣62.不同路径、63. 不同路径 II

1.不同路径

代码随想录

视频讲解:动态规划中如何初始化很重要!| LeetCode:62.不同路径_哔哩哔哩_bilibili

代码:

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        // dp[i][j] 表示从起点走到坐标为i,j的地方的方法数
        vector<vector<int>> dp(m,vector<int>(n,0));
        // 初始化
        for(int i = 0;i < m; i++) dp[i][0] = 1;
        for(int j = 0;j < n; j++) dp[0][j] = 1;
        // 递归公式
        for(int i = 1;i < m; i++){
            for(int j = 1;j < n ;j++){
                dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
            }
        }
        return dp[m - 1][n - 1];
    }
};

思路:

dp数组的含义:从起点走到坐标为i,j的方法数

递推公式:因为只能向右或向下走,所以dp[i][j] = dp[i - 1][j] + dp[i][j - 1]

初始化:因为是由左方的方法数,和上方的方法数推出来的,因此,我们只需要初始化最上方的行,和最左边的列。而我们的dp数组的含义是方法数,因此,它们全部初始化为1.

遍历顺序:从上到下,从左到右

这道题,我还是出错了,虽然我递推公式写对了,但是我在初始化的时候,没有想到我的dp数组表示方法数,我写成了步数。

2.不同路径2

代码随想录
视频讲解:https://www.bilibili.com/video/BV1Ld4y1k7c6

代码:

cpp 复制代码
class Solution {
public:
    int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
        int m = obstacleGrid.size();
        int n = obstacleGrid[0].size();
        vector<vector<int>> dp(m,vector<int>(n,0));
        // 初始化
        for(int i = 0;i < m && obstacleGrid[i][0] == 0;i++){
            dp[i][0] = 1;
        }
        for(int j = 0;j < n && obstacleGrid[0][j] == 0;j++){
            dp[0][j] = 1;
        }
        // 递推公式
        for(int i = 1;i < m; i++){
            for(int j = 1;j < n; j++){
                if(obstacleGrid[i][j] == 0){
                    dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
                }
            }
        }
        return dp[m - 1][n - 1];
    }
};

思路:

dp数组的含义:从起点走到坐标为i,j的方法数

递推公式:因为只能向右或向下走,所以dp[i][j] = dp[i - 1][j] + dp[i][j - 1]

初始化:因为是由左方的方法数,和上方的方法数推出来的,因此,我们只需要初始化最上方的行,和最左边的列。而我们的dp数组的含义是方法数,因此,它们全部初始化为1.

遍历顺序:从上到下,从左到右

和上一题的区别主要体现在初始化和递推公式上,在初始化时,如果遇到了障碍,就应该停止初始化(这样没有被初始化的dp元素默认为0种方法);在递推时,加上判断条件,判断我们的目标地点没有障碍时,再进行递推。

相关推荐
电鱼智能的电小鱼几秒前
无人机巡检智能边缘计算终端技术方案‌‌——基于EFISH-SCB-RK3588工控机/SAIL-RK3588核心板的国产化替代方案‌
网络·人工智能·嵌入式硬件·算法·机器人·无人机·边缘计算
Macle_Chen37 分钟前
ios版本的Tiktok二次安装不上,提示:Unable to Install “TikTok”
ios·职场和发展·蓝桥杯
纪元A梦1 小时前
分布式拜占庭容错算法——实现工作量证明(PoW)算法详解
java·分布式·算法
_李白_1 小时前
分布式互斥算法
分布式·算法
楽码2 小时前
概率算法的空乘就坐问题
后端·算法·机器学习
Dontla2 小时前
git引用概念(git reference,git ref)(简化对复杂SHA-1哈希值的管理)(分支引用、标签引用、HEAD引用、远程引用、特殊引用)
git·算法·哈希算法
做科研的周师兄2 小时前
中国区域30m/15天植被覆盖度数据集(2010-2022)
大数据·javascript·算法·性能优化·数据分析
BothSavage2 小时前
尝试使用gocryptfs实现大模型加密部署
算法
我想睡觉2612 小时前
Python训练营打卡DAY44
开发语言·人工智能·python·深度学习·算法·机器学习
闻缺陷则喜何志丹2 小时前
【二分图 图论】P9384 [THUPC 2023 决赛] 着色|普及+
c++·算法·图论·二分图·洛谷