难度
机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为“Finish”)。
现在考虑网格中有障碍物。那么从左上角到右下角将会有多少条不同的路径?
示例1:

输入:obstacleGrid = [[0,0,0],[0,1,0],[0,0,0]]输出:2解释:3x3 网格的正中间有一个障碍物。从左上角到右下角一共有 2 条不同的路径:1. 向右 -> 向右 -> 向下 -> 向下2. 向下 -> 向下 -> 向右 -> 向右
实例2:

输入:obstacleGrid = [[0,1],[0,0]]输出:1
题解
如果有障碍物,那么到该格的可能就为0。
因为只能往左或往下,所以第一行和第一列,如果有障碍物,则障碍物后面的可能也为0。
class Solution {public int uniquePathsWithObstacles(int[][] obstacleGrid) {int row = obstacleGrid.length;int col = obstacleGrid[0].length;int[][] dp = new int[row][col];int init = 1;for(int i = 0; i < row; i++) {if(obstacleGrid[i][0] == 1) {init = 0;}dp[i][0] = init;}init = 1;for(int i = 0; i < col; i++) {if(obstacleGrid[0][i] == 1) {init = 0;}dp[0][i] = init;}for(int i = 1; i < row; i++) {for(int j = 1; j < col; j++) {if(obstacleGrid[i][j] == 1) {dp[i][j] = 0;} else {dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}}return dp[row - 1][col - 1];}}
