LeetCode题练习与总结:不同路径Ⅱ--63

一、题目描述

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

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

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

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

示例 1:

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

示例 2:

输入:obstacleGrid = [[0,1],[0,0]]
输出:1

提示:

  • m == obstacleGrid.length
  • n == obstacleGrid[i].length
  • 1 <= m, n <= 100
  • obstacleGrid[i][j]01

二、解题思路

  1. 初始化:dp[0][0]是起始点,如果obstacleGrid[0][0]为0,则dp[0][0] = 1,否则为0。表示没有路径可以到达起点上存在障碍物的网格。
  2. 状态转移方程:对于dp[i][j],它只能由dp[i-1][j](从左边来)和dp[i][j-1](从上边来)转移而来。如果obstacleGrid[i][j]为1,则表示该位置有障碍物,dp[i][j]为0。否则,dp[i][j] = dp[i-1][j] + dp[i][j-1]
  3. 遍历:从左到右,从上到下遍历obstacleGrid,根据状态转移方程更新dp数组。
  4. 结果:最后dp[m-1][n-1]即为从左上角到右下角的不同路径数量。

三、具体代码

class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        // 获取网格的行数和列数
        int m = obstacleGrid.length;
        int n = obstacleGrid[0].length;

        // 初始化dp数组,所有元素初始为0
        int[][] dp = new int[m][n];

        // 如果起点有障碍物,则直接返回0
        if (obstacleGrid[0][0] == 1) {
            return 0;
        }

        // 初始化起点为1,表示从起点出发至少有一条路径
        dp[0][0] = 1;

        // 遍历网格
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                // 如果当前位置有障碍物,则跳过
                if (obstacleGrid[i][j] == 1) {
                    dp[i][j] = 0;
                    continue;
                }
                // 从左边来
                if (i > 0) {
                    dp[i][j] += dp[i-1][j];
                }
                // 从上边来
                if (j > 0) {
                    dp[i][j] += dp[i][j-1];
                }
            }
        }

        // 返回到达右下角的路径数量
        return dp[m-1][n-1];
    }
}

四、时间复杂度和空间复杂度

1. 时间复杂度
  • 外层循环遍历每一行,内层循环遍历每一列,所以总共的循环次数是 m * n,其中 m 是网格的行数,n 是网格的列数。
  • 在每次循环中,代码主要进行的是常数时间的操作,包括数组的读写操作和简单的加法运算。
  • 由于没有嵌套循环或递归调用,且没有额外的复杂操作,所以时间复杂度是 O(m * n)。
2. 空间复杂度
  • 空间复杂度主要由创建的二维数组 dp 决定,其大小为 m * n。
  • dp 数组用于存储到达每个位置的路径数量,这是解决这个问题所需的额外空间。
  • 代码中没有使用其他额外的数据结构或变量,所以空间复杂度是 O(m * n)。

五、总结知识点

1. 二维数组的使用:代码中使用了二维数组 dp 来存储从起点到每个位置的路径数量。这是动态规划问题中常见的数据结构,用于保存问题的子解。

2. 动态规划(Dynamic Programming):这是一个典型的动态规划问题。动态规划是一种通过将问题分解为重叠的子问题,并存储子问题的解(通常是在一个表格中),从而避免重复计算子问题的解的优化技巧。

  • 状态定义:dp[i][j] 表示从左上角到位置 (i, j) 的不同路径数量。
  • 状态转移方程:dp[i][j] = dp[i-1][j] + dp[i][j-1]obstacleGrid[i][j] 为 0 时,表示没有障碍物,可以从上方或左方到达当前位置。
  • 初始化:dp[0][0] 为 1,因为起点没有障碍物,且只有一条路径可以到达起点。

3. 条件判断:代码中使用了条件判断来处理障碍物的情况。如果当前位置有障碍物(obstacleGrid[i][j] == 1),则 dp[i][j] 被设置为 0,表示没有路径可以到达该位置。

4. 循环控制:代码使用了两层嵌套的 for 循环来遍历整个网格。外层循环遍历行,内层循环遍历列。这种循环结构适用于处理网格、矩阵等二维结构的问题。

5. 空间复杂度优化:尽管代码中没有直接体现,但在实际应用中,可以考虑使用一维数组来优化空间复杂度,因为 dp[i][j] 只依赖于 dp[i-1][j]dp[i][j-1],不需要整个二维数组 dp

  • 可以通过仅使用两行空间(一个用于当前行,一个用于前一行)来更新路径数量,从而将空间复杂度从 O(m * n) 降低到 O(min(m, n))。

6. 边界条件处理:代码在处理动态规划问题时,特别注意了边界条件。在这个问题中,起点 dp[0][0] 是一个特殊的边界条件,如果起点有障碍物,则没有路径可以到达,直接返回 0。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/538080.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

如何使用SQL注入工具?

前言 今天来讲讲SQL注入工具&#xff0c;sqlmap。如何使用它来一步步爆库。 sqlmap官方地址如下。 sqlmap: automatic SQL injection and database takeover tool 前期准备&#xff0c;需要先安装好docker、docker-compose。 一个运行的后端服务&#xff0c;用于写一个存在…

竞赛 图像识别-人脸识别与疲劳检测 - python opencv

文章目录 0 前言1 课题背景2 Dlib人脸识别2.1 简介2.2 Dlib优点2.3 相关代码2.4 人脸数据库2.5 人脸录入加识别效果 3 疲劳检测算法3.1 眼睛检测算法3.3 点头检测算法 4 PyQt54.1 简介4.2相关界面代码 5 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是…

AI大模型创新交汇点:当AI遇见艺术

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

【面试题】细说mysql中的各种锁

前言 作为一名IT从业人员&#xff0c;无论你是开发&#xff0c;测试还是运维&#xff0c;在面试的过程中&#xff0c;我们经常会被数据库&#xff0c;数据库中最经常被问到就是MySql。当面试官问MySql的时候经常会问道一个问题&#xff0c;”MySQL中有哪些锁&#xff1f;“当我…

NAPI 类对象导出及其生命周期管理(上)

1.NAPI 类对象导出 OpenHarmony NAPI提供了一种“包装”C 类和实例的方法&#xff0c;以便JS应用可以调用类的构造函数和方法。Node.js Node-API中关于导出类对象的内容&#xff0c; 1.1. NAPI导出类对象流程 通过napi_define_class定义一个JS类 它包含了与 C 类对应的构造函…

PandasAI的应用与实战解析(一):环境安装、运行demo

文章目录 1.源码包下载、明确依赖版本2.安装python依赖3.运行demo 本博客源码仓库地址&#xff1a;gitlab&#xff0c;本篇博客对应01分支python版本为3.10.x 什么是PandasAI&#xff1f;一句话总结的话&#xff0c;PandasAI就是一个结合了Pandas和AI的开源工具&#xff0c;更…

单链表和文件操作使用练习:通讯录

1. 项目文件组成&#xff08;vs2022&#xff09; 1. Contact.h和Contact.c分别为实现通讯录的头文件和源文件。 2. SList.h和SList.c分别为实现单链表的头文件和源文件。 3. test.c为测试用的源文件&#xff0c;用于调用通讯录提供的函数。 4. Contact.txt用于存储联系人信息。…

蓝桥杯 每日2题 day5

碎碎念&#xff1a;哦哈呦&#xff0c;到第二天也是哦哈哟&#xff0c;&#xff0c;学前缀和差分学了半天&#xff01;day6堂堂连载&#xff01; 0.单词分析 14.单词分析 - 蓝桥云课 (lanqiao.cn) 关于这题就差在input前加一个sorted&#xff0c;记录一下下。接下来就是用字…

【饿了么笔试题汇总】[全网首发]2024-04-12-饿了么春招笔试题-三语言题解(CPP/Python/Java)

&#x1f36d; 大家好这里是KK爱Coding &#xff0c;一枚热爱算法的程序员 ✨ 本系列打算持续跟新饿了么近期的春秋招笔试题汇总&#xff5e; &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&#x…

决策树与随机森林实验报告(纯Python实现)

一、实验内容简介 该实验主要利用ID3算法和已有的数据建立决策树和随机森林&#xff0c;并利用决策树和随机森林来预测未知数据的值。本实验使用Python实现。 二、算法说明 下面介绍几个基础但很重要的概念&#xff1a; 决策树&#xff1a;决策树是在已知各种情况发生概率的…

如何恢复 iPhone 删除的照片?

照片是iPhone空间不足的主要原因&#xff0c;因此许多用户选择删除一些重复或不喜欢的图片来释放设备。然而&#xff0c;人们在清洁过程中不小心遗漏了自己喜欢的照片的情况很常见。如果你找不到这些珍贵的照片&#xff0c;你一定很难过。其实&#xff0c;您不必担心这个问题&a…

Android 纵向双选日历

这个日历的布局分两部分&#xff0c;一部分是显示星期几的LinearLayout&#xff0c;另外就是一个RecyclerView&#xff0c;负责纵向滚动了。 工具类&#xff1a; implementation com.blankj:utilcode:1.17.3上activity_calendar代码&#xff1a; <?xml version"1.0&…

【教资】总结经验篇

4月.12日概述 今天是2024年上半学期中小学出成绩的一天&#xff0c;查到成绩的那一刻是灰常让人激动的&#xff0c;很开心&#xff0c;特此记下此时的真实感受&#xff0c;我也没有去问别人怎么样&#xff0c;特此针对自己以记之&#xff0c;加上最近有点摆烂&#xff0c;所以…

重磅!李彦宏内部讲话曝光,百度AI闭源策略引爆争议!|TodayAI

最近&#xff0c;百度公司创始人、董事长兼CEO李彦宏的一次内部讲话内容被公之于众。在这次讲话中&#xff0c;李彦宏表达了几个与行业普遍看法相左的观点&#xff0c;尤其在开源与闭源策略的选择上&#xff0c;引发了业界的广泛关注和讨论。 李彦宏在讲话中明确指出了百度对开…

gitlab、jenkins安装及使用文档二

安装 jenkins IP地址操作系统服务版本192.168.75.137Rocky9.2jenkins 2.450-1.1 jdk 11.0.22 git 2.39.3192.168.75.138Rocky9.2gitlab-ce 16.10.0 结合上文 jenkins安装 前期准备&#xff1a; yum install -y epel-release yum -y install net-tools vim lrzsz wget…

git知识

如何将develop分支合并到master分支 #简单版 git checkout master git pull origin master git merge origin/develop # 解决可能的冲突并提交 git push origin master#复杂版 git checkout master # 拉取远程 master 分支的最新代码并合并到本地 git pull origin master # 拉…

网页内容生成图片,这18般武艺你会几种呢?

前言 关于【SSD系列】&#xff1a; 前端一些有意思的内容&#xff0c;旨在3-10分钟里&#xff0c; 500-1000字&#xff0c;有所获&#xff0c;又不为所累。 网页截图&#xff0c;windows内置了快捷命令和软件&#xff0c;chrome开发者工具也能一键截图&#xff0c;html2canva…

【Linux杂货铺】文件系统

目录 &#x1f308;前言&#x1f308; &#x1f4c1; 硬盘 &#x1f4c2; 物理结构 &#x1f4c2; 存储结构 &#x1f4c2; CHS定址法 &#x1f4c2; 操作系统对硬盘的管理和抽象 &#x1f4c1; 文件系统 &#x1f4c2; 分区 &#x1f4c2; 分组 &#x1f4c2; inode号 分配…

DL00295-基于AirSim仿真环境的无人机深度强化学习算法路径规划完整实现含详细说明文档

-创建了一个开放的AI Gym环境&#xff0c;包括多旋翼和固定翼无人机的运动学模型。 -提供了一些UE4环境来训练和测试深度强化学习DRL导航策略。 -基于AirSim和SB3。 完整代码链接见文末。 DL00295-基于AirSim仿真环境的无人机深度强化学习算法路径规划完整实现含详细说明文档

力扣HOT100 - 189. 轮转数组

解题思路&#xff1a; 三次反转。 先反转一次&#xff0c;再根据 k 拆分成两部分各反转一次。 class Solution {public void rotate(int[] nums, int k) {k % nums.length;reverse(nums, 0, nums.length - 1);reverse(nums, 0, k - 1);reverse(nums, k, nums.length - 1);}pu…