LeetCode第2577题-在网格图中访问一个格子的最少时间-python实现-图解思路与手撕代码

news2024/11/16 23:34:32

LeetCode第2577题-在网格图中访问一个格子的最少时间-python实现-图解思路与手撕代码

文章目录

  • 一、题目描述
  • 二、解题思路与代码实现
    • 1.解题思路
    • 2.代码实现
  • 总结


一、题目描述

在这里插入图片描述

二、解题思路与代码实现

1.解题思路

这道题求最短距离,首先检查起始点0,0的右边0,1和下边1,0,如果这两个点的值都大于1,那这道题无解,直接返回-1。

如果起始点的右边和下边都小于等于1,那就可以通过反复横跳的形式到达任意一个点,例如当前点是1,下一个点是3,那可以先跳到上一个点变成2,再跳回来变成3,这样就可以跳到下一个点变成4。

这样从当前点到周围点的距离要么是当前距离+1,要么是反复横跳之后+1。

如果需要反复横跳,那么到达这个点的时间和这个点的横纵坐标之和的奇偶性相同,这点可以证明。

所以最后的结果需要根据( i + j )的奇偶性判断是否要+1

最后为了保证最短距离,需要把所有遍历过的点都存储起来,每次取出最短距离的点检查其上下左右,这一点在代码的最后进一步讨论。

2.代码实现

代码如下(示例):

class Solution:
    def minimumTime(self, grid: List[List[int]]) -> int:
        m,n=len(grid),len(grid[0])
        if grid[0][1]>1 and grid[1][0]>1:return -1
        dis=[[inf]*n for _ in range(m)]
        dis[0][0]=0
        # h存储(距离,x,y),因为不知道那一条路线是最短路径,所有处理过的所有点都要存储起来
        # 从h中不断取出距离最短的点,检查其上下左右,直到到达右下角
        h=[(0,0,0)]
        while True:
            d,i,j = heappop(h)
            if i==m-1 and j==n-1:return d
            for x,y in (i-1,j),(i+1,j),(i,j-1),(i,j+1):
                # 遍历(i,j)上下左右四个点
                if 0<=x<m and 0<=y<n:
                    # 到周围点的距离要么是当前距离+1,要么是反复横跳之后+1
                    # 如果需要反复横跳以使得已经经过的时间大于周围点所要求的的最小时间
                    # 那么到达这个点的时间和这个点的横纵坐标之和的奇偶性相同
                    nd=max(d+1,grid[x][y])
                    nd+=(nd-x-y)%2
                    # 如果求出的nd小于dis中存储的值,就更新
                    if nd<dis[x][y]:
                        dis[x][y]=nd
                        heappush(h,(nd,x,y))

对于h的作用,我们可以在每次while循环中打印h的长度和内容检查其作用。

print(len(h))
print(h)
1
[(0, 0, 0)]
2
[(1, 0, 1), (5, 1, 0)]
3
[(2, 1, 1), (5, 1, 0), (4, 0, 2)]
4
[(3, 1, 2), (3, 2, 1), (4, 0, 2), (5, 1, 0)]
5
[(3, 2, 1), (5, 1, 0), (4, 0, 2), (8, 2, 2), (6, 1, 3)]
5
[(4, 0, 2), (4, 2, 0), (6, 1, 3), (8, 2, 2), (5, 1, 0)]
5
[(4, 2, 0), (5, 0, 3), (6, 1, 3), (8, 2, 2), (5, 1, 0)]
4
[(5, 0, 3), (5, 1, 0), (6, 1, 3), (8, 2, 2)]
3
[(5, 1, 0), (8, 2, 2), (6, 1, 3)]
2
[(6, 1, 3), (8, 2, 2)]
2
[(7, 2, 3), (8, 2, 2)]

可以发现,通过存储所有遍历过的点,并不断取出距离最小的点,可以实现最短路径的目的。


总结

这道题对于图和最短距离的讨论是非常有价值的。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux配置mysql主从复制

Linux配置mysql主从复制 systemctl restart mysqld 重启mysql服务 Mysql主从复制 在linux里面部署mysql 主库Master 192.168.162.138 contos 7 从库Slave 192.168.162.137 contos 7测试 log-binmysql-bin町[必须]启用二进制日志 第三步:登录Mysql数据库&#xff0c;执…

oracle 19c 创建物化视图并测试logminer进行日志挖掘

1、创建物化视图 alter session set containerpdb; grant create materialized view to scott; create materialized view 物化视图名 -- 1. 创建物化视图 build [immediate | deferred] -- 2. 创建方式&#xff0c;默认 immediate refre…

LeetCode-2373. 矩阵中的局部最大值【矩阵,数组】

LeetCode-2373. 矩阵中的局部最大值【矩阵&#xff0c;数组】题目描述&#xff1a;解题思路一&#xff1a;原地修改。首先将每个3*3的矩阵的最大值存放在左上角的点&#xff0c;然后修改给的grid矩阵的大小。解题思路二&#xff1a;暴力&#xff0c;申请一个数组解题思路三&…

想学Java开发,有什么方式可以选择?

想学习软件开发Java高级编程语言的小伙伴看过来&#xff0c;这里有多年Java职业教育经验总结以及学习技巧分享&#xff0c;不容错过的精彩内容&#xff01; 一年之计在于春&#xff0c;阳春三月是学习的好时光。万物复苏&#xff0c;一切都可以重新开始&#xff0c;如果你也在考…

一些开源的,好看的前端组件/样式库

以下是一些受欢迎的开源 CSS 样式库&#xff1a;Bootstrap&#xff1a;https://getbootstrap.com/Materialize CSS&#xff1a;https://materializecss.com/Bulma&#xff1a;https://bulma.io/Foundation&#xff1a;https://foundation.zurb.com/Semantic UI&#xff1a;http…

智慧燃气管理系统

在数字经济时代&#xff0c;迫切需要通过数字化建设智能天然气&#xff0c;提高天然气的基本安全水平&#xff0c;提高企业的智能管理水平。这是人们可以看到、触摸和使用的智能应用&#xff0c;也是为智能城市奠定良好基础的必修课。智能燃气是以GIS为基础&#xff0c;采用物联…

商简智能计划与排程SPS在纺织行业中的应用

企业背景 某织造、染色及后整理一体化工艺的纺织面料企业&#xff0c;主要从事户外功能运动服装、内衣、泳衣、汽车内饰等面料的研发和销售&#xff0c;年产值在20亿左右&#xff0c;是迪卡侬运动面料最优质供应商之一。 纺织行业特点 印染具有典型的流程行业特性&#xff0c…

从功能测试到自动化测试,我只花了67天,薪资翻倍

在这个吃技术的IT行业来说&#xff0c;我刚入行的时候每天做的也是最基础的工作&#xff0c;但是随着时间的消磨&#xff0c;我产生了对自我和岗位价值和意义的困惑。 随着移动互联网的发展&#xff0c;从业人员能力的整体进步&#xff0c;软件测试需要具备的能力要求越来越高…

Databend 开源周报 第 82 期

Databend 是一款现代云数仓。专为弹性和高效设计&#xff0c;为您的大规模分析需求保驾护航。自由且开源。即刻体验云服务&#xff1a;https://app.databend.com 。Whats New探索 Databend 本周新进展&#xff0c;遇到更贴近你心意的 Databend 。Features & Improvements :…

vue源码分析-基础的数据代理检测

简单回顾一下这个系列的前两节&#xff0c;前两节花了大量的篇幅介绍了Vue的选项合并&#xff0c;选项合并是Vue实例初始化的开始&#xff0c;Vue为开发者提供了丰富的选项配置&#xff0c;而每个选项都严格规定了合并的策略。然而这只是初始化中的第一步&#xff0c;这一节我们…

【计算机组成原理 - 第一章】计算机系统概论(完结)

本章参考王道考研相关课程&#xff1a; 【2021版】1.2.1_计算机硬件的基本组成_哔哩哔哩_bilibili 【2021版】1.2.2_认识各个硬件部件_哔哩哔哩_bilibili 【2021版】1.2.3_计算机系统的层次结构_哔哩哔哩_bilibili 【2021版】1.3_计算机的性能指标_哔哩哔哩_bilibili 目录 一、…

绘制带有角度的CAD图形

这个CAD图形用到的命令有CAD直线、CAD圆、CAD圆弧、CAD偏移和CAD旋转等多个CAD命令相结合才绘制出来。 目标对象 操作步骤 1.先使用直线命令画相交于A点的两条线段&#xff0c;然后A点为圆心画半径12和半径15的圆 2.然后以B点为圆心画半径2的圆&#xff0c;使用复制命令指定圆…

Maven的基本使用

1.Maven的基本介绍2.Maven中仓库的概念3.Maven中坐标的概念坐标示例如下&#xff1a;<dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.13</version><scope>test</scope>//这个是范围 &l…

elasticsearch 8 修改分词器并数据迁移

1. 安装中文索引 下载地址&#xff1a;https://github.com/medcl/elasticsearch-analysis-ik/releases 注意&#xff1a;版本要和ES版本对应 解压后放入plugins文件中 然后重启服务&#xff1a;docker-compose restart elasticsearch&#xff0c;大概需要1分钟 2. 数据迁移…

【Spark分布式内存计算框架——Spark Streaming】9. 获取偏移量 应用案例:百度搜索风云榜(上)

4.4 获取偏移量 当SparkStreaming集成Kafka时&#xff0c;无论是Old Consumer API中Direct方式还是New Consumer API方式获取的数据&#xff0c;每批次的数据封装在KafkaRDD中&#xff0c;其中包含每条数据的元数据信息。 文档&#xff1a;http://spark.apache.org/docs/2.4.…

重磅:Meta未来4年路线图曝光,Quest出货超2000万台

The Verge今天曝光了一份Meta内部AR/VR产品规划图&#xff0c;这份规划图为Meta高管为Reality Labs员工的内部分享&#xff0c;包括了大量AR/VR产品信息&#xff0c;下面我们一起来看看。一&#xff0c;未来四年规划Meta Reality Labs四年规划&#xff1a;1&#xff0c;2023年&…

你知道吗?火狐搜集您的数据?

导读请注意,打包在 Firefox Web 浏览器里面的地理位置服务即使浏览器关闭后也会在后台运行。我们还没有从关于浏览器插件丑闻的消息中平复下来。插件原本目的是保卫隐私&#xff0c;但现在却把信息卖给了第三方公司。然而更令人愤怒的是其规模完全超出我们的预计。MLS MLS&…

报错“FirewallD is not running”怎么办,如何解决?

目录 一、报错详情 二、解决方法—开启防火墙步骤 步骤一&#xff1a;先通过命令查看一下防火墙的状态。 步骤二&#xff1a;开启防火墙。 步骤三&#xff1a;再次查看防火墙状态 一、报错详情 在docker创建redis容器&#xff0c;在进行window访问redis容器端口进行绑定设…

IGKBoard(imx6ull)-ADC编程MQ-2烟雾传感器采样

文章目录1- ADC介绍2- MQ-2烟雾传感器介绍&#xff08;1&#xff09;工作原理&#xff08;2&#xff09;MQ-2应用电路3- MQ-2烟雾传感器硬件连接4- ADC驱动配置5- 编程查看当前浓度1- ADC介绍 ADC是Analog-to-Digital Converter的缩写&#xff0c;指模数转换器。真实世界的模拟…

【C#基础】C# 预处理器指令

序号系列文章8【C#基础】C# 面向对象编程9【C# 基础】C# 异常处理操作10【C#基础】C# 正则表达式文章目录前言1&#xff0c;预处理器指令的概念2&#xff0c;预处理器指令的定义与使用2.1&#xff0c;可为空上下文2.2&#xff0c;定义符号2.3&#xff0c;条件编译2.4&#xff0…