面试算法-83-不同路径 II

题目

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish”)。

现在考虑网格中有障碍物。那么从左上角到右下角将会有多少条不同的路径?

网格中的障碍物和空位置分别用 1 和 0 来表示。

示例 1:
在这里插入图片描述

输入:obstacleGrid = [[0,0,0],[0,1,0],[0,0,0]]
输出:2
解释:3x3 网格的正中间有一个障碍物。
从左上角到右下角一共有 2 条不同的路径:

  1. 向右 -> 向右 -> 向下 -> 向下
  2. 向下 -> 向下 -> 向右 -> 向右

class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        int m = obstacleGrid.length;
        int n = obstacleGrid[0].length;

        int[][] dp = new int[m][n];
        boolean flag = false;
        for (int i = 0; i < m; i++) {
            if (obstacleGrid[i][0] != 1) {
                dp[i][0] = 1;
            } else {
                flag = true;
            }
            if (flag) {
                dp[i][0] = 0;
            }
        }

        flag = false;
        for (int j = 0; j < n; j++) {
            if (obstacleGrid[0][j] != 1) {
                dp[0][j] = 1;
            } else {
                flag = true;
            }
            if (flag) {
                dp[0][j] = 0;
            }
        }

        for (int i = 1; i < m; i++) {
            for (int j = 1; j < n; j++) {
                if (obstacleGrid[i][j] != 1) {
                    dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
                } else {
                    dp[i][j] = 0;
                }
            }
        }
        return dp[m - 1][n - 1];
    }
}

相关推荐

  1. 算法D39 | 动态规划2 | 62.不同路径 63. 不同路径 II

    2024-03-24 22:48:03       46 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-24 22:48:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-24 22:48:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-24 22:48:03       82 阅读
  4. Python语言-面向对象

    2024-03-24 22:48:03       91 阅读

热门阅读

  1. Linux系统docker创建MySQL服务

    2024-03-24 22:48:03       42 阅读
  2. opencv瑕疵检测一般流程

    2024-03-24 22:48:03       36 阅读
  3. 话题——AI大模型学习

    2024-03-24 22:48:03       41 阅读
  4. VisionPro 9.0 64位下载地址

    2024-03-24 22:48:03       35 阅读
  5. vue3中defineProps详解

    2024-03-24 22:48:03       42 阅读
  6. vue3组合式api(一)

    2024-03-24 22:48:03       36 阅读
  7. Vue实现父组件向子组件传值

    2024-03-24 22:48:03       35 阅读
  8. mac如何安装homebrew

    2024-03-24 22:48:03       45 阅读
  9. EPCS1、EPCS4、EPCS16数据手册解读

    2024-03-24 22:48:03       38 阅读
  10. 爬虫系统介绍

    2024-03-24 22:48:03       35 阅读
  11. python笔记基础--函数(5)

    2024-03-24 22:48:03       32 阅读