代码随想录算法训练营第四十二天|62.不同路径、63. 不同路径 II

代码随想录算法训练营第四十二天|62.不同路径、63. 不同路径 II

码农世界 2024-06-05 前端 95 次浏览 0个评论

62.不同路径

文档讲解:代码随想录

题目链接:. - 力扣(LeetCode)

 

记录每个格子的状态 二维矩阵-->二维dp数组

dp数组

题目是要求到达最后一个格子有多少种路径

所以dp[i,j]: 到达第(i,j)个格子有多少种路径

递推公式

到达一个格子只能是由上一个格子向右走或者向下走,所以目标格子的前一个格子有如下几种情况:

dp[i,j] = dp[i,j-1] +dp[i-1,j] 

dp数组如何初始化

dp[0,i]=1,dp[0,j]=1

遍历顺序

初始值在左上面

从上向下,从左向右

class Solution:
    def uniquePaths(self, m: int, n: int) -> int:
        dp = [[0] * n for _ in range(m)]
        #初始化第一行
        for j in range(0,n):
            dp[0][j] = 1
        #初始化第一列
        for i in range(0,m):
            dp[i][0] = 1
        #递推,从上往下,从左往右
        for i in range(1,m):
            for j in range(1,n):
                dp[i][j] = dp[i][j-1] + dp[i-1][j]
        return dp[m-1][n-1]

63. 不同路径 II

文档讲解:代码随想录

题目链接:. - 力扣(LeetCode)

 遇上一题类似

递推公式加了一个前提条件,[i][j]需要没有障碍

最大的差异在于初始化:遇到一个障碍之后,第一列和第一行后面的值就都是0了

class Solution:
    def uniquePathsWithObstacles(self, obstacleGrid: List[List[int]]) -> int:
        n = len(obstacleGrid[0])
        m = len(obstacleGrid)
        print(m,n)
        dp = [[0] * n for _ in range(m)]
        #初始化第一行
        for j in range(0,n):
            if obstacleGrid[0][j]!=1:
                dp[0][j] = 1
            else:
                break
        #初始化第一列
        for i in range(0,m):
            if obstacleGrid[i][0]!=1:
                dp[i][0] = 1
            else:
                break
        #递推,从上往下,从左往右
        for i in range(1,m):
            for j in range(1,n):
                if obstacleGrid[i][j]!=1:
                    dp[i][j] = dp[i][j-1] + dp[i-1][j]
        return dp[m-1][n-1]

转载请注明来自码农世界,本文标题:《代码随想录算法训练营第四十二天|62.不同路径、63. 不同路径 II》

百度分享代码,如果开启HTTPS请参考李洋个人博客
每一天,每一秒,你所做的决定都会改变你的人生!

发表评论

快捷回复:

评论列表 (暂无评论,95人围观)参与讨论

还没有评论,来说两句吧...

Top