不同路径 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),因为我们需要创建一个二维数组来存储路径数。

相关内容

热门资讯

第三分钟开挂!赣牌圈控制牌型辅... 较多好评“微乐万能挂官网”开挂(透视)辅助教程 了解更多开挂安装加(136704302)微信号是一款...
第十分钟透视!财神十三张辅助(... >>您好:财神十三张辅助确实是有挂的,很多玩家在这款财神十三张辅助游戏中打牌都会发现很多用户的牌特别...
第十分钟发现!葫芦娃辅助器直装... 葫芦娃辅助器直装是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微...
5分钟发现!宝宝游戏辅助(辅助... 5分钟发现!宝宝游戏辅助(辅助挂)其实真的是有挂(安装教程开挂辅助下载) 【无需打开直接搜索加薇13...
5分钟辅助!微信老铁13水辅助... 5分钟辅助!微信老铁13水辅助(辅助挂)其实是有挂(AI教程开挂辅助平台)【无需打开直接搜索加薇13...
2分钟了解!黑科技透视工具(辅... 您好:这款黑科技透视工具游戏是可以开挂的,确实是有挂的,很多玩家在这款黑科技透视工具游戏中打牌都会发...
9分钟讲解!雀友会广东潮汕bu... 9分钟讲解!雀友会广东潮汕bus(辅助挂)一直真的是有挂(wpk教程开挂辅助插件)>>您好:软件加1...
5分钟辅助!新玄龙辅助(辅助挂... 5分钟辅助!新玄龙辅助(辅助挂)原来确实有挂(必备教程开挂辅助平台)新玄龙辅助ai黑科技系统规律教程...
第三分钟辅助!有没有哈糖大菠萝... 第三分钟辅助!有没有哈糖大菠萝攻略推荐(辅助挂)一贯确实有挂(德州论坛开挂辅助平台);亲,有没有哈糖...
1分钟详情!广东老友辅助(辅助... 1分钟详情!广东老友辅助(辅助挂)一贯确实有挂(AI教程开挂辅助下载)【无需打开直接搜索加薇1367...