不同路径 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辅助神器,有需要的用户可以加我...
玩家必备攻略“朱雀吴江三缺一辅... 较多好评“微乐万能挂官网”开挂(透视)辅助教程 了解更多开挂安装加(136704302)微信号是一款...
技巧知识分享“小程序跑得快的技... 技巧知识分享“小程序跑得快的技巧”开挂(透视)辅助神器AI教程(有挂分析)您好:小程序跑得快的技巧这...
玩家必备攻略“518互游辅助”... 您好:518互游辅助这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特...
一分钟揭秘“宝宝浙江游戏开挂器... 宝宝浙江游戏开挂器开挂教程视频分享装挂详细步骤在当今的网络游戏中,宝宝浙江游戏开挂器作为一种经典的娱...
记者揭秘“微乐河南麻将辅助io... 记者揭秘“微乐河南麻将辅助ios”开挂(透视)辅助工具揭秘攻略(有挂教程);无需打开直接搜索微信(1...
推荐十款“aapoker免费透... 大家好,今天小编来为大家解答aapoker免费透视脚本这个问题咨询软件客服可以免费测试直接加微信(1...
透视安卓版“中至小程序破檞”开... 【亲,中至小程序破檞 这款游戏可以开挂的,确实是有挂的,很多玩家在这款中至小程序破檞中打牌都会发现很...