跟进“不同的路径”:
现在考虑网格中有障碍物,那样将会有多少条不同的路径?
网格中的障碍和空位置分别用1和0来表示。
您在真实的面试中是否遇到过这个题?
Yes
样例
如下所示在3x3的网格中有一个障碍物:
[
[0,0,0],
[0,1,0],
[0,0,0]
]
一共有2条不同的路径从左上角到右下角。
注意
标签
Expand
m和n均不超过100
AC代码:
public class Solution {
/**
* @param obstacleGrid: A list of lists of integers
* @return: An integer
*/
public int uniquePathsWithObstacles(int[][] obstacleGrid) {
// write your code here
int re[][]= obstacleGrid;
re[0][0]= re[0][0]== 1 ? 0 : 1;
for(int i=1;i<re.length;i++){
re[i][0] = re[i][0]==1?0:re[i-1][0];
}
for(int j=1;j<re[0].length;j++){
re[0][j] = re[0][j]==1?0:re[0][j-1];
}
for(int i=1;i<re.length;i++)
{
for(int j=1;j<re[i].length;j++){
re[i][j] = re[i][j]==1?0:re[i-1][j]+re[i][j-1];
}
}
return re[re.length-1][re[0].length-1];
}
}
/**
* @param obstacleGrid: A list of lists of integers
* @return: An integer
*/
public int uniquePathsWithObstacles(int[][] obstacleGrid) {
// write your code here
int re[][]= obstacleGrid;
re[0][0]= re[0][0]== 1 ? 0 : 1;
for(int i=1;i<re.length;i++){
re[i][0] = re[i][0]==1?0:re[i-1][0];
}
for(int j=1;j<re[0].length;j++){
re[0][j] = re[0][j]==1?0:re[0][j-1];
}
for(int i=1;i<re.length;i++)
{
for(int j=1;j<re[i].length;j++){
re[i][j] = re[i][j]==1?0:re[i-1][j]+re[i][j-1];
}
}
return re[re.length-1][re[0].length-1];
}
}