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]


















