代码随想录算法训练营29期Day39|LeetCode 62,63

文档讲解:不同路径 不同路径II

62.不同路径

题目链接: https://leetcode.cn/problems/unique-paths/description/

思路:

我们很清楚的知道一点,当前位置只能由两个点到达,左边的点和上边的点。即到当前点的路径数目 = 到左边点的路径数目 + 到上边点的路径数目。

设 dp[ i ][ j ] 为到达 (i,j) 点的路径数目,则dp[ i ][ j ]=dp[ i-1 ][ j ]+dp[ i ][ j-1 ];

那我们就知道遍历顺序为从上到下,从左到右。同时初始状态为dp[1][1]=1,即到达起点的路径只有一条。

核心代码:

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        int dp[105][105];
        memset(dp,0,sizeof(dp));
        dp[1][1]=1;
        for(int i=1;i<=m;i++)
          for(int j=1;j<=n;j++){
              if(i==1&&j==1) continue;
              dp[i][j]=dp[i-1][j]+dp[i][j-1];
          }
        return dp[m][n];
    }
};

63.不同路径II

题目链接: https://leetcode.cn/problems/unique-paths-ii/description/

思路:

我们很清楚的知道一点,当前位置只能由两个点到达,左边的点和上边的点。即到当前点的路径数目 = 到左边点的路径数目 + 到上边点的路径数目。

设 dp[ i ][ j ] 为到达 (i,j) 点的路径数目,则dp[ i ][ j ]=dp[ i-1 ][ j ]+dp[ i ][ j-1 ];

那我们就知道遍历顺序为从上到下,从左到右。同时初始状态为dp[1][1]=1,即到达起点的路径只有一条。

到目前的思路都和上一道题目一样。

这题有个不同的地方,就是某些点上会有障碍,障碍点是不能走的,也就是说到达障碍点的路径条数为0,这一点需要我们在遍历时特判一下,其他的就没问题了。

核心代码:

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

今日总结

今日学习时长1h,题难度也还算可以,题目非常的经典。

相关推荐
一只鹿鹿鹿6 小时前
信息安全等级保护安全建设防护解决方案(总体资料)
运维·开发语言·数据库·面试·职场和发展
卷福同学6 小时前
QClaw内测体验,能用微信指挥AI干活了
人工智能·算法·ai编程
sali-tec7 小时前
C# 基于OpenCv的视觉工作流-章34-投影向量
图像处理·人工智能·opencv·算法·计算机视觉
xiaoye-duck7 小时前
《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂
数据结构·c++·算法·递归
Eward-an7 小时前
【算法竞赛/大厂面试】盛最多水容器的最大面积解析
python·算法·leetcode·面试·职场和发展
山栀shanzhi7 小时前
归并排序(Merge Sort)原理与实现
数据结构·c++·算法·排序算法
阿豪学编程7 小时前
LeetCode438: 字符串中所有字母异位词
算法·leetcode
Trouvaille ~7 小时前
【递归、搜索与回溯】专题(七):FloodFill 算法——勇往直前的洪水灌溉
c++·算法·leetcode·青少年编程·面试·蓝桥杯·递归搜索回溯
地平线开发者7 小时前
征程 6P codec decoder sample
算法·自动驾驶
地平线开发者7 小时前
征程 6X Camera 接入数据评估
算法·自动驾驶