Unique Paths II

LeetCode Q 63 - Unique Paths II

A robot is located at the top-left corner of a m x n grid (marked ‘Start’ in the diagram below).
The robot can only move either down or right at any point in time. The robot is trying to reach the bottom-right corner of the grid (marked ‘Finish’ in the diagram below).
Now consider if some obstacles are added to the grids. How many unique paths would there be?
An obstacle and empty space is marked as 1 and 0 respectively in the grid.
Note: m and n will be at most 100.

Comparing with Unique Path, now we have obstable!

Example 1:
Input: [ [0,0,0], [0,1,0], [0,0,0] ] Output: 2
Explanation:
There is one obstacle in the middle of the 3x3 grid above.
There are two ways to reach the bottom-right corner:

  1. Right -> Right -> Down -> Down
  2. Down -> Down -> Right -> Right

Solution

Solution 1: DP using an additional array

public int uniquePathsWithObstacles(int[][] obstacleGrid) {
	if (obstacleGrid == null || obstacleGrid.length == 0 || obstacleGrid[0].length == 0)
		return 0;
	
	int row = obstacleGrid.length, col = obstacleGrid[0].length;
	int[][] dp = new int[row][col];
	for (int i = 0; i < row; i++) {
		if (obstacleGrid[i][0] == 0) dp[i][0] = 1;
		else break;
	}
	
	for (int j = 0; j < col; j++) {
		if (obstacleGrid[0][j] == 0) dp[0][j] = 1;
		else break;
	}
	
	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];
}

Solution 2: DP in place

public int uniquePathsWithObstacles(int[][] obstacleGrid) {
	int R = obstacleGrid.length;
	int C = obstacleGrid[0].length;

	// If the starting cell has an obstacle, then simply return as there would be
	// no paths to the destination.
	if (obstacleGrid[0][0] == 1) return 0;
	
	// Number of ways of reaching the starting cell = 1.
	obstacleGrid[0][0] = 1;

	// Filling the values for the first column
	for (int i = 1; i < R; i++) {
		obstacleGrid[i][0] = (obstacleGrid[i][0] == 0 && obstacleGrid[i - 1][0] == 1) ? 1 : 0;
	}

	// Filling the values for the first row
	for (int i = 1; i < C; i++) {
		obstacleGrid[0][i] = (obstacleGrid[0][i] == 0 && obstacleGrid[0][i - 1] == 1) ? 1 : 0;
	}

	// Starting from cell(1,1) fill up the values
	// No. of ways of reaching cell[i][j] = cell[i - 1][j] + cell[i][j - 1]
	// i.e. From above and left.
	for (int i = 1; i < R; i++) {
		for (int j = 1; j < C; j++) {
			if (obstacleGrid[i][j] == 0) obstacleGrid[i][j] = obstacleGrid[i - 1][j] + obstacleGrid[i][j - 1];
			else obstacleGrid[i][j] = 0;
		}
	}

	// Return value stored in rightmost bottommost cell. That is the destination.
	return obstacleGrid[R - 1][C - 1];
}

   Reprint policy


《Unique Paths II》 by Tong Shi is licensed under a Creative Commons Attribution 4.0 International License
 Previous
Minimum Path Sum Minimum Path Sum
LeetCode Q 64 - Minimum Path SumGiven a m x n grid filled with non-negative numbers, find a path from top left to bottom
2019-04-22 Tong Shi
Next 
Unique Paths Unique Paths
LeetCode Q 62 - Unique PathsA robot is located at the top-left corner of a m x n grid (marked ‘Start’ in the diagram bel
2019-04-22 Tong Shi
  TOC