leetcode hot100不同路径Ⅱ

本题和之前做的不同路径类似,区别是本题中加入了障碍,遇到障碍之后需要避开(注意,这里依旧是只能向下向右移动),那么也就是说,有障碍的点是到达不了的,并且 ,我在初始化的时候,如果第一行或者第一列有障碍,那无法绕过去,因为只能向右向下移动!

也就是说这个题最大的区别就是初始化的位置需要进行额外的判断,另外一个地方就是在递推公式的时候,只有我们能走到下一个位置,也就是下一个位置不是障碍的时候,我们才能递推,进行累加结果,如果是障碍,那应该直接将路径置为0。

按照动态规划五部曲来做:

确定dp数组及其含义:dp数组表示到达指定位置的路径的个数

确定递推公式:如果目标点没有障碍,那么就是dp[i][j] = dp[i-1][j] + dp[i][j-1]。如果是障碍则直接置为0。

初始化dp数组:和上述一样,我们依旧初始化第一行和第一列,当遇到障碍后便不再初始化!

确定遍历顺序:依旧从左到右,从上到下(题中条件)

打印数组

复制代码
class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        int m = obstacleGrid.length;
        int n = obstacleGrid[0].length;
        int[][] dp = new int[m][n];

        //如果在起点或终点出现了障碍,直接返回0
        if (obstacleGrid[m - 1][n - 1] == 1 || obstacleGrid[0][0] == 1) {
            return 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++) {
                dp[i][j] = (obstacleGrid[i][j] == 0) ? dp[i - 1][j] + dp[i][j - 1] : 0;
            }
        }
        return dp[m - 1][n - 1];
    }
}

注意,这里关于m和n的边界选取依旧和上一题一样!

相关推荐
白云千载尽28 分钟前
leetcode 912.排序数组
算法·leetcode·职场和发展
哆啦刘小洋30 分钟前
Tips:预封装约束的状态定义
算法
代码充电宝30 分钟前
LeetCode 算法题【简单】290. 单词规律
java·算法·leetcode·职场和发展·哈希表
Juan_20121 小时前
P1040题解
c++·算法·动态规划·题解
Onesoft%J1ao1 小时前
C++竞赛递推算法-斐波那契数列常见题型与例题详解
c++·算法·动态规划·递推·信息学奥赛
以己之1 小时前
NC313 两个数组的交集
算法·哈希算法
Brookty2 小时前
【算法】前缀和
java·学习·算法·前缀和·动态规划
And_Ii2 小时前
LeetCode 3397. 执行操作后不同元素的最大数量
数据结构·算法·leetcode
额呃呃2 小时前
leetCode第33题
数据结构·算法·leetcode
隐语SecretFlow2 小时前
【隐语SecretFlow用户案例】亚信科技构建统一隐私计算框架探索实践
科技·算法·安全·隐私计算·隐私求交·开源隐私计算