代码随想录训练营第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];}
};

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...