本文主要是介绍代码随想录算法训练营第四十二天|62.不同路径、63. 不同路径 II,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
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] = 1else:break#初始化第一列for i in range(0,m):if obstacleGrid[i][0]!=1:dp[i][0] = 1else: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的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!