不同路径 II
创始人
2025-01-09 11:00:27
0

以下是一个示例代码,用于解决LeetCode上的“不同路径 II”问题:

def uniquePathsWithObstacles(obstacleGrid):
    # 获取网格的行数和列数
    m = len(obstacleGrid)
    n = len(obstacleGrid[0])
    
    # 创建一个二维数组,用于存储到达每个位置的不同路径数
    dp = [[0] * n for _ in range(m)]
    
    # 初始化起点位置的路径数为1
    dp[0][0] = 1 if obstacleGrid[0][0] == 0 else 0
    
    # 处理第一列的路径数
    for i in range(1, m):
        if obstacleGrid[i][0] == 0:
            dp[i][0] = dp[i-1][0]
    
    # 处理第一行的路径数
    for j in range(1, n):
        if obstacleGrid[0][j] == 0:
            dp[0][j] = dp[0][j-1]
    
    # 计算其他位置的路径数
    for i in range(1, m):
        for j in range(1, n):
            if obstacleGrid[i][j] == 0:
                dp[i][j] = dp[i-1][j] + dp[i][j-1]
    
    # 返回终点位置的路径数
    return dp[m-1][n-1]

在这个解决方法中,我们使用动态规划来计算不同路径的数量。首先,我们创建一个二维数组dp,用于存储到达每个位置的不同路径数。然后,我们初始化起点位置的路径数为1。接下来,我们处理第一列和第一行的路径数,如果网格中的障碍物位置为0,则路径数与上一个位置的路径数相同,否则路径数为0。最后,我们计算其他位置的路径数,对于每个位置,如果网格中的障碍物位置为0,则路径数等于上方和左方位置的路径数之和。最终,返回终点位置的路径数。

这个解决方法的时间复杂度是O(mn),其中m和n分别是网格的行数和列数。空间复杂度也是O(mn),因为我们需要创建一个二维数组来存储路径数。

相关内容

热门资讯

推荐十款!poker worl... 推荐十款!poker world辅助器,xpoker辅助助手,wepoke教程(有挂解说)1、pok...
一分钟揭秘!哈糖大菠萝怎么开挂... 一分钟揭秘!哈糖大菠萝怎么开挂,sohoo辅助,必胜教程(有挂教程)暗藏猫腻,小编详细说明哈糖大菠萝...
攻略讲解!we poker免费... 攻略讲解!we poker免费辅助器(透视脚本)详细透视辅助黑科技(好像是真的有挂)亲,关键说明,w...
重大通报!聚星ai辅助工具收费... 重大通报!聚星ai辅助工具收费多少(透视脚本)详细透视辅助机制(确实真的是有挂)1、聚星ai辅助工具...
终于知道!xpoker辅助怎么... 终于知道!xpoker辅助怎么用,拱趴大菠萝作弊方法,可靠教程(有挂介绍)1、首先打开拱趴大菠萝作弊...
教学盘点!epoker免费透视... 教学盘点!epoker免费透视脚本,xpoker怎么作弊,玩家教你(有挂攻略);亲,关键说明,epo...
我来教教大家!xpoker透视... 我来教教大家!xpoker透视辅助(透视脚本)详细透视辅助挂(好像是真的有挂)1、每一步都需要思考,...
今日百科!德州之星扫描器,约局... 今日百科!德州之星扫描器,约局吧德州真的有透视挂吗,新2025教程(有挂技巧)在进入约局吧德州真的有...
玩家必看科普!德州透视脚本,x... 玩家必看科普!德州透视脚本,xpoker辅助助手,攻略方法(有挂解密);1、上手简单,内置详细流程视...
八分钟德州局透视!德州辅助工具... 八分钟德州局透视!德州辅助工具到底怎么样,智星德州辅助译码插件靠谱吗,详细教程(有挂方法);1、该软...