代码随想录训练营第39天|LeetCode 62.不同路径、63. 不同路径 II
创始人
2024-03-15 10:00:50
0

参考

代码随想录

题目一:LeetCode 62.不同路径

相比于之前的爬楼梯,这题变成了二维,对于某个位置[i,j],可以从[i-1,j]或者[i,j-1]走到[i,j],因此在求解思想上其实是类似于爬楼梯的。

  1. 确定dp数组及其下标的含义
    dp[i][j]为从[0,0]位置走到[i,j]位置的路径数
  2. 确定递归公式
    每次可以选择往右或往下走,当前在边界处除外,因此每个位置有两种方式到达,递推公式为
dp[i][j] = dp[i-1][j] + dp[i][j-1]
  1. 初始化dp数组
    需要初始化第一行和第一列,一方面是因为第一行和第一列的dp数组的值是确定的,都为1(因为在第一行,每次只能往右走,在第一列,每次只能往下走),另一方面,后面的dp数组需要由前面的数值推出来。初始化代码如下:
for(int i = 0; i < m; i++)  dp[i][0] = 1;
for(int i = 0; i < n; i++)  dp[0][i] = 1;
  1. 确定遍历顺序
    对于每一行,从左往右遍历;对于每一列,从上往下遍历。先遍历行还是先遍历列都可以,遍历顺序是由递推公式来决定的,dp[i][j]要由dp[i-][j]和dp[i][j-1]推出来。
  2. 举例推导dp数组
    在这里插入图片描述
    整体的代码实现如下:
class Solution {
public:int uniquePaths(int m, int n) {vector> dp(m,vector((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-1][j] + dp[i][j-1];       }}return dp[m-1][n-1];}
};

题目二:LeetCode 63.不同路径II

这个题在上一个题的基础之上加入了障碍物,如下图,因为障碍物的存在,图中红色方框标记的两个地方只能由一个方向过来。思路上没有问题,但是这样在代码实现上稍微有些复杂,换个思路,只要把障碍物所在的地方的dp数组的值标记为0就可以了,这里的dp数组的含义与上一个题一致。
在这里插入图片描述

  1. 确定dp数组及其下标的含义
    dp[i][j]为从[0,0]位置走到[i,j]位置的路径数
  2. 确定递归公式
    每次可以选择往右或往下走,当前在边界处除外,因此每个位置有两种方式到达,递推公式为
dp[i][j] = dp[i-1][j] + dp[i][j-1]
  1. 初始化dp数组
    dp数组的初始化要注意,如果第一行或第一列的某个位置出现障碍物,则后面的都应该初始化为0,如下图所示:
    在这里插入图片描述
    在这里插入图片描述
for(int i = 0; i < m && !obstacleGrid[i][0]; i++) dp[i][0] = 1;
for(int j = 0; j < n && !obstacleGrid[0][j]; j++) dp[0][j] = 1;
  1. 确定遍历顺序
    对于每一行,从左往右遍历;对于每一列,从上往下遍历。先遍历行还是先遍历列都可以,遍历顺序是由递推公式来决定的,dp[i][j]要由dp[i-][j]和dp[i][j-1]推出来。

5.举例推导dp数组
在这里插入图片描述
在这里插入图片描述
完整的代码实现如下:

class Solution {
public:int uniquePathsWithObstacles(vector>& obstacleGrid) {int m = obstacleGrid.size();int n = obstacleGrid[0].size();vector> dp(m,vector((n)));for(int i = 0; i < m && !obstacleGrid[i][0]; i++) dp[i][0] = 1;for(int j = 0; j < n && !obstacleGrid[0][j]; j++) dp[0][j] = 1;for(int i = 1; i < m; i++){for(int j = 1; j < n; j++){if(obstacleGrid[i][j]) dp[i][j] = 0;else   dp[i][j] = dp[i-1][j] + dp[i][j-1];       }}return dp[m-1][n-1];}
};

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...