代码随想录算法训练营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 ;

那我们就知道遍历顺序为从上到下,从左到右。同时初始状态为dp11=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 ;

那我们就知道遍历顺序为从上到下,从左到右。同时初始状态为dp11=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,题难度也还算可以,题目非常的经典。

相关推荐
汤姆yu4 分钟前
macOS系统下Aider完整安装、配置与实战使用教程
大数据·人工智能·算法·macos·github·copilot
Sam092713 分钟前
【AI 算法精讲 14】TF-IDF:词频与逆文档频率
人工智能·python·算法·ai
王老师青少年编程13 分钟前
2026年6月GESP真题及题解(C++五级):排排坐
c++·题解·真题·gesp·五级·2026年6月·排排坐
郝学胜-神的一滴30 分钟前
Qt 高级编程 034:深耕QWidget底层内核—彻底吃透无边框窗口设计核心原理
开发语言·c++·qt·程序人生·软件开发·用户界面
编程圈子41 分钟前
电机驱动开发学习18. SVPWM空间矢量调制算法详解与实现
驱动开发·学习·算法
不会写代码的ys41 分钟前
C++复习篇
java·开发语言·c++
大鱼>1 小时前
机器学习基础:从零理解核心概念与算法分类
算法·机器学习·分类
AI科技星1 小时前
基于32维Cayley_Dickson超复数的全域拓扑统一场论——反重力、真空自持供能、维度瞬移与星际宇宙脑秩序体系
人工智能·学习·算法·机器学习·数据挖掘
aichitang20241 小时前
数论变换(NTT)
c++·算法·fft·ntt
_olone1 小时前
AtCoder Beginner Contest 465 D - X to Y
c++·算法