63.不同路径 II

不同路径 II

一个机器人位于一个 m x n 网格的左上角。网格中的障碍物和空位置分别用 1 和 0 来表示。机器人每次只能向下或者向右移动一步,求到达右下角的不同路径数。

示例 1:

输入:obstacleGrid = [[0,0,0],[0,1,0],[0,0,0]]
输出:2

示例 2:

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

解析

1
2
3
4
5
6
7
8
9
10
11
12
var uniquePathsWithObstacles = function (obstacleGrid) {
const m = obstacleGrid.length, n = obstacleGrid[0].length;
const dp = Array.from({ length: m }, () => Array(n).fill(0));
for (let i = 0; i < m && obstacleGrid[i][0] === 0; i++) dp[i][0] = 1;
for (let j = 0; j < n && obstacleGrid[0][j] === 0; j++) dp[0][j] = 1;
for (let i = 1; i < m; i++) {
for (let j = 1; j < n; j++) {
dp[i][j] = obstacleGrid[i][j] === 1 ? 0 : dp[i - 1][j] + dp[i][j - 1];
}
}
return dp[m - 1][n - 1];
};

63.不同路径 II
https://leetcode.lz5z.com/63.unique-paths-ii/
作者
tickli
发布于
2023年11月13日
许可协议