D34|不同路径
2023-12-16 23:34:46
62.不同路径
初始思路:
1)确定dp数组以及下标的含义:
? ? ? ? ? ? ? ?dp[i][i]存放到第i+1行和第i+1列的方法数
2)确定递推公式:
? ? ? ? dp[i][i]?= dp[i -1][i]?+ dp[i][i-1]
3)dp数组如何初始化
? ? ? ? 第0行是1;
? ? ? ? 第0列是1;
4)确定遍历顺序
从前到后
5)举例推导dp数组
class Solution {
public int uniquePaths(int m, int n) {
int[][] dp = new int[m][n];
for(int i = 0;i<m;i++){
dp[i][0] = 1;
}
for(int i = 0;i<n;i++){
dp[0][i] = 1;
}
for(int i =1;i<m;i++){
for(int j = 1;j<n;j++){
dp[i][j] = dp[i][j-1] + dp[i-1][j];
}
}
return dp[m-1][n-1];
}
}
题解复盘:
? ? ? ? 基本一致?。
?63. 不同路径 II
初始思路:
在前一题的基础之上增加了对障碍数组的判断,如果第一行中有一个障碍,那么这个障碍后面的dp全部赋值为0,前面的都赋值为1;列同理。
再过程中遇到障碍,令当前dp为0即可。
class Solution {
public int uniquePathsWithObstacles(int[][] obstacleGrid) {
int m = obstacleGrid.length;
int n = obstacleGrid[0].length;
int[][] dp = new int[m][n];
for(int i = 0;i<m;i++){
if(obstacleGrid[i][0]==1){
break;
}
dp[i][0] = 1;
}
for(int i = 0;i<n;i++){
if(obstacleGrid[0][i]==1){
break;
}
dp[0][i] = 1;
}
for(int i =1;i<m;i++){
for(int j = 1;j<n;j++){
if(obstacleGrid[i][j]==1){dp[i][j] = 0;}
else{
dp[i][j] = dp[i][j-1] + dp[i-1][j];
}
}
}
return dp[m-1][n-1];
}
}
?
文章来源:https://blog.csdn.net/Q77ian/article/details/135038225
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!