:::danger 代码还没有完成
- 动态方程
- 边界情况:对于目标位置arr[m-1][n-1]的周围被围绕这个边界情况遗漏了。 :::
/*** @param {number[][]} obstacleGrid* @return {number}*/var uniquePathsWithObstacles = function(obstacleGrid) {let m = obstacleGrid.lengthlet n = obstacleGrid[0].lengthif (m === 1 && n === 1) return obstacleGrid[0][0] === 0 ? 1 : 0if (m === 1) return obstacleGrid[0].includes(1) ? 0 : 1if (n === 1) {for (let i = 0; i<m; i++) {if (obstacleGrid[i][0] === 1) return 0}}if (obstacleGrid[0][0] === 1 || obstacleGrid[m-1][n-1] === 1) return 0for (let i = 0; i<m; i++) obstacleGrid[i][0] = obstacleGrid[i][0] === 0 ? 1 : 0for (let i = 0; i<n; i++) obstacleGrid[0][i] = obstacleGrid[0][i] === 0 ? 1 : 0for (let i = 1; i<m; i++) {for (let j = 1; j<n; j++) {obstacleGrid[i][j] === 1? obstacleGrid[i][j] = 0: obstacleGrid[i][j] = obstacleGrid[i-1][j] + obstacleGrid[i][j-1]}}return obstacleGrid[m-1][n-1]};
