当前位置: 首页 > article >正文

【Leetcode 每日一题】63. 不同路径 II

问题背景

给定一个 m × n m \times n m×n 的整数数组 g r i d grid grid。一个机器人初始位于 左上角(即 g r i d [ 0 ] [ 0 ] grid[0][0] grid[0][0])。机器人尝试移动到 右下角(即 g r i d [ m − 1 ] [ n − 1 ] grid[m - 1][n - 1] grid[m1][n1])。机器人每次只能向下或者向右移动一步。
网格中的障碍物和空位置分别用 1 1 1 0 0 0 来表示。机器人的移动路径中不能包含 任何 有障碍物的方格。
返回机器人能够到达右下角的不同路径数量。
测试用例保证答案小于等于 2 × 1 0 9 2 \times 10 ^ 9 2×109

数据约束

  • m = o b s t a c l e G r i d . l e n g t h m = obstacleGrid.length m=obstacleGrid.length
  • n = o b s t a c l e G r i d [ i ] . l e n g t h n = obstacleGrid[i].length n=obstacleGrid[i].length
  • 1 ≤ m , n ≤ 100 1 \le m, n \le 100 1m,n100
  • o b s t a c l e G r i d [ i ] [ j ] obstacleGrid[i][j] obstacleGrid[i][j] 0 0 0 1 1 1

解题过程

和以前做过的图相关动态规划题非常类似,自己做的时候先想到的是用方向数组来模拟,把自己绕进去了。

具体实现

递归

class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        int m = obstacleGrid.length;
        int n = obstacleGrid[0].length;
        int[][] memo = new int[m][n];
        for (int[] row : memo) {
            Arrays.fill(row, -1);
        }
        return dfs(m - 1, n - 1, obstacleGrid, memo);
    }

    private int dfs(int i, int j, int[][] obstacleGrid, int[][] memo) {
        if (i < 0 || j < 0 || obstacleGrid[i][j] == 1) {
            return 0;
        }
        if (i == 0 && j == 0) {
            return 1;
        }
        if (memo[i][j] != -1) {
            return memo[i][j];
        }
        return memo[i][j] = dfs(i - 1, j, obstacleGrid, memo) + dfs(i, j - 1, obstacleGrid, memo);
    }
}

递推

class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        int m = obstacleGrid.length;
        int n = obstacleGrid[0].length;
        int[][] dp = new int[m + 1][n + 1];
        dp[0][1] = 1;
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                if (obstacleGrid[i][j] == 0) {
                    dp[i + 1][j + 1] = dp[i][j + 1] + dp[i + 1][j];
                }
            }
        }
        return dp[m][n];
    }
}
空间优化
class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        int m = obstacleGrid.length;
        int n = obstacleGrid[0].length;
        int[] dp = new int[n + 1];
        dp[1] = 1;
        for (int[] row : obstacleGrid) {
            for (int j = 0; j < n; j++) {
                if (row[j] == 0) {
                    dp[j + 1] += dp[j];
                } else {
                    dp[j + 1] = 0;
                }
            }
        }
        return dp[n];
    }
}

http://www.kler.cn/a/538291.html

相关文章:

  • Redis 集群(Cluster)和基础的操作 部署实操篇
  • 每日一题——没有重复项数字的全排列
  • AD域控粗略了解
  • 【自开发工具】SQLSERVER的ImpDp和ExpDp工具汇总
  • 物联网软件开发与应用方向应该怎样学习,学习哪些内容,就业方向是怎样?(文末领取整套学习视频,课件)物联网硬件开发与嵌入式系统
  • 33. 搜索旋转排序数组
  • 计算机组成原理(3)
  • Tengine配置负载均衡加健康检查
  • 【AI】人工智能与搜索引擎知识了解
  • 高效 MyBatis SQL 写法一
  • 【Vue】在Vue3中使用Echarts的示例 两种方法
  • Shapefile格式文件解析和显示
  • Ubuntu系统apt镜像源报错解决思路
  • Python 实现 gRPC 与 原始 RPC 的对比:理解 RPC 的基本功能
  • 解释 Vue 3 中的 Composition API
  • css中字体的加载,仅在使用的时候加载,会阻塞,用font-display:swap
  • uni-app vue3 使用笔记
  • [手机Linux] onepluse6T 系统重新分区
  • MySQL数据库(七)SQL 优化
  • 扩展知识--缓存和分时复用cpu
  • TensorFlow域对抗训练DANN神经网络分析MNIST与Blobs数据集梯度反转层提升目标域适应能力可视化...
  • 除了wps还有什么表格软件可以在上面切换不用单独启动窗口
  • Python截图轻量化工具
  • MySQL部署基于二进制日志文件位置的主从复制集群
  • 使用Jenkins、K8S、Docker一键部署SpringCloud微服务
  • 【AI智能时代】QA素质模型和知识等级分类