【力扣】63. 不同路径 II <动态规划>

【力扣】63. 不同路径 II

一个机器人位于一个 m m m x n n n 网格的左上角 (起始点在下图中标记为 "Start" )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 "Finish")。

现在考虑网格中有障碍物。那么从左上角到右下角将会有多少条不同的路径?网格中的障碍物和空位置分别用 1 和 0 来表示。

示例 1:

起点 0 0
0 障碍 0
0 0 终点

输入:obstacleGrid = \[0,0,0,0,1,0,0,0,0]

输出:2

解释:3x3 网格的正中间有一个障碍物。

从左上角到右下角一共有 2 条不同的路径:

    1. 向右 -> 向右 -> 向下 -> 向下
    1. 向下 -> 向下 -> 向右 -> 向右

示例 2:

起点 障碍
0 终点

输入:obstacleGrid = \[0,1,0,0]

输出:1

提示:

m == obstacleGrid.length

n == obstacleGridi.length

1 <= m, n <= 100

obstacleGridij 为 0 或 1

题解

  • 确定 dp 数组以及下标的含义
    dpij :表示从 (0,0) 出发,到 (i, j) 有 dpij 条不同的路径。
  • 确定递推公式
    想要求 dpij,只能有两个方向来推导出来,即 dpi - 1j 和 dpij - 1
    dpi - 1j 表示是从 (0, 0) 的位置到 (i - 1, j) 有几条路径,dpij - 1同理
    dpij = dpi - 1j + dpij - 1,因为 dpij 只有这两个方向过来。
    因为有了障碍,(i, j) 如果就是障碍的话应该就保持初始状态(初始状态为0)。
  • dp 数组如何初始化
    dpi0 一定都是1,因为从 (0, 0) 的位置到 (i, 0) 的路径只有一条,那么 dp0j 也同理。
    但如果 (i, 0) 这条边有了障碍之后,障碍之后(包括障碍)都是走不到的位置了,所以障碍之后的 dpi0 应该还是初始值0。下标(0, j)的初始化情况同理。
  • 确定遍历顺序
    dpij 都是从其上方和左方推导而来
  • 举例推导 dp 数组(打印 dp 数组)
java 复制代码
public 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;
        }
        //dp数组初始化,若有障碍,后面都是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];
    }
}
相关推荐
8Qi815 小时前
LeetCode 235. 二叉搜索树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·二叉搜索树·lca·迭代
心之伊始16 小时前
Java 后端接入大模型:从 Token、并发到推理成本的完整估算方法
java·spring boot·性能优化·大模型·llm
8Qi817 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
BlackTurn17 小时前
技术经理投标
java
YG亲测源码屋17 小时前
java配置环境变量、jdk环境变量配置、java环境变量设置方法
java·开发语言
MIUMIUKK17 小时前
从语法层面,看懂 Python 的特殊处
java·开发语言·python
hujinyuan2016017 小时前
2026年3月 中国电子学会青少年软件编程(Python)三级考试试卷 真题及答案
java·python·算法
basketball61618 小时前
C++ 高级编程:2. 基本线程池实现
java·开发语言·c++
MageGojo18 小时前
天气 API 接入实战:基于 ApiZero 实现实时天气、分钟级降水和 15 天预报查询
java·后端·spring·api 接口接入·接口实战
自动跟随18 小时前
UWB自动跟随技术全栈解析:从定位算法到“位控一体化“
java·网络·人工智能