【LeetCode】每日一题 2023_11_9 逃离火灾(bfs 练习)
文章目录
- 刷题前唠嗑
- 题目:最长平衡子字符串
- 题目描述
- 代码与解题思路
- 偷看大佬题解
- 结语
刷题前唠嗑

LeetCode? 启动!!!
嗯?什么?今天是 hard?陷入沉思。。。先看看题吧
题目:最长平衡子字符串
题目链接:2258. 逃离火灾
题目描述

这题目可太长啦,不过题意还是挺好理解滴
代码与解题思路
type pair struct { x, y int }
var dir = []pair{{-1, 0}, {1, 0}, {0, -1}, {0, 1}}func maximumMinutes(grid [][]int) int {m, n := len(grid), len(grid[0])// bfs 函数:取三个数, 到达安全屋/安全屋上边/安全屋左边bfs := func(q []pair) (int, int, int) {time := make([][]int, m)for i, _ := range time { // 给 time 数组赋值为 -1time[i] = make([]int, n)for j, _ := range time[i] {time[i][j] = -1 // 表示未访问该点}}for _, v := range q { // 设置起点time[v.x][v.y] = 0}for t := 1; len(q) > 0; t++ {tmp := qq = nilfor _, v := range tmp {for _, v2 := range dir {// x, y 设置偏移量, 然后控制边界, grid == 0 表示能走(不是墙), time < 0 也就是 == -1 表示未访问该节点if x, y := v.x+v2.x, v.y+v2.y; x >= 0 && x < m && y >= 0 && y < n && grid[x][y] == 0 && time[x][y] < 0 { time[x][y] = tq = append(q, pair{x, y}) // 需要 bfs 的新坐标起点}}}}return time[m-1][n-1], time[m-1][n-2], time[m-2][n-1]}manToHouseTime, m1, m2 := bfs([]pair{{0, 0}})if manToHouseTime < 0 { // 人能否到安全屋return -1}firPos := []pair{}for i, row := range grid { // 收集火的位置for j, x := range row {if x == 1 {firPos = append(firPos, pair{i, j})}}}fireToHouseTime, f1, f2 := bfs(firPos)if fireToHouseTime < 0 { // 火能否到安全屋return 1_000_000_000}d := fireToHouseTime - manToHouseTime if d < 0 { // 火到安全屋的时间是否比人快return -1}// 如果人需要从上面或左边进入安全屋, 与火到这两个位置的时间进行比较if m1 != -1 && m1+d < f1 || m2 != -1 && m2+d < f2 { return d}return d-1
}
我就非常朴素的把题目翻译了一遍,算是模拟题意吧,具体是这样的:
首先需要分析的就是,火和人一起走向安全屋,如果火到安全屋的上面或者左边之后,人就进不了安全屋了,所以我们在进行 bfs 搜索最短路的时候需要返回 安全屋/安全屋上面/安全屋左边 这几个位置,考虑火把人进入安全屋的路径挡住的情况
- 首先 bfs 人,查看是否能进安全屋,如果不能就返回 -1
- 然后遍历地图,收集火的位置
- 然后 bfs 火,查看火能否进安全屋,如果不能就返回 1_000_000_000
- 然后判断火到安全屋的时间是否比人快,如果比人快就返回 -1
- 最后判断火是否会到安全屋的上方或左方对人进入安全屋造成影响,如果有影响就让人少等一分钟,提前进安全屋,如果没影响就正常返回前往安全屋的时间
按照这个思路一步步走,最后结果没什么问题
偷看大佬题解
emmm
二分查找,我去看了看,我尝试理解,理解失败。。。开摆,今天就到这里吧~
结语
今天的每日一题就当是练习 bfs 啦
相关文章:
【LeetCode】每日一题 2023_11_9 逃离火灾(bfs 练习)
文章目录 刷题前唠嗑题目:最长平衡子字符串题目描述代码与解题思路偷看大佬题解 结语 刷题前唠嗑 LeetCode? 启动!!! 嗯?什么?今天是 hard?陷入沉思。。。先看看题吧 题目:最长平…...
flink1.18.0 自适应调度器 资源弹性缩放 flink帮你决定并行度
jobmanager.scheduler Elastic Scaling | Apache Flink 配置文件修改并重启flink后,webui上会显示调整并行度的按钮,他可以自己调整,你也可以通过webUI手动调整: 点击 之后: 调整完成后:...
如何设计vue项目的权限管理?
权限管理的重要性及必要性 数据安全:权限管理可以确保只有具有相应权限的用户能够访问和操作特定的数据。这可以保护敏感数据不被未授权的用户访问,从而提高数据的安全性。功能控制:权限管理可以根据用户的角色和权限设置,控制用户…...
HBase学习笔记(2)—— API使用
对HBase中常用的API操作进行简单的介绍 对应HBase学习笔记(1)—— 知识点总结-CSDN博客中介绍的HBase Shell常用操作 更多用法请参考官网:Apache HBase ™ Reference Guide 依赖导入 <dependencies><dependency><groupId>o…...
C/C++轻量级并发TCP服务器框架Zinx-游戏服务器开发004:游戏核心消息处理 - 玩家类的实现
文章目录 0 代码仓库1 需求2 AOI设计2.1 AOI算法简介2.2 AOI数据结构及实现2.2.1 玩家2.2.2 网格对象2.2.3 游戏世界矩形2.2.4 获取周围玩家的实现2.2.5 代码测试 2.3 GameRole结合AOI创建玩家2.3.1 创建游戏世界全局对象-GameRole继承AOIWorld的Player2.3.2 把玩家到游戏世界的…...
Python Selenium元素定位方法详解
引言 在Web自动化测试中,元素定位是一项非常重要的技术。Python Selenium提供了各种元素定位方法,可以帮助我们定位页面上的元素并与之交互。本文将详细介绍Python Selenium中常用的元素定位方法,并提供实例代码。 1. ID定位 ID是元素在HT…...
分布式事务,你了解多少?(上)
本文主要是讲述分布式事务的理论及常用的技术方案,主要源自各类学习和工作总结,如有不妥之处,还望指正。分布式事务的其他基础请自行查阅资料。 一、分布式事务产生的原因 分布式事务的产生,源自互联网、电商等的发展,…...
ClickHouse主键索引最佳实践
在本文中,我们将深入研究ClickHouse索引。我们将对此进行详细说明和讨论: ClickHouse的索引与传统的关系数据库有何不同ClickHouse是怎样构建和使用主键稀疏索引的ClickHouse索引的最佳实践 您可以选择在自己的机器上执行本文给出的所有Clickhouse SQL…...
Flink 基础 -- 应用开发(项目配置)
1、概述 本节中的指南将向您展示如何通过流行的构建工具(Maven, Gradle)配置项目,添加必要的依赖项(即连接器和格式,测试),并涵盖一些高级配置主题。 每个Flink应用程序都依赖于一组Flink库。至少,应用程序依赖于Flink api&…...
空间曲面@常见曲面方程
文章目录 曲面的基本问题特殊曲面球面方程球的标准形方程一般形方程例 柱面柱面方程不同维度下同方程的图形常见柱面方程 旋转曲面旋转曲面的方程旋转情况分类以yOz上的曲线绕 z z z轴旋转为例 旋转曲面的方程常见旋转曲面方程 锥面其他曲面 曲面的基本问题 根据曲面(点的几何…...
unity 接收和发送Udp消息
因为需要用到unity和其他的程序交互,其他程序可以提供Udp消息,因此找了合适的相互连接方法。这里直接上代码。 工具类: using System; using System.Collections; using System.Collections.Generic; using System.IO; using System.Net; u…...
机器学习股票大数据量化分析与预测系统 - python 计算机竞赛
文章目录 0 前言1 课题背景2 实现效果UI界面设计web预测界面RSRS选股界面 3 软件架构4 工具介绍Flask框架MySQL数据库LSTM 5 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 机器学习股票大数据量化分析与预测系统 该项目较为新颖&am…...
架构描述语言(ADL)
1.架构描述语言(ADL) 架构描述语言(Architecture Description Language, ADL)是一种为明确说明软件系统的概念架构和对这些概念架构建模提供功能的语言。 2.ADL基本构成要素 ADL即架构描述语言,其基本构成要素包括:…...
GZ038 物联网应用开发赛题第2套
2023年全国职业院校技能大赛 高职组 物联网应用开发 任 务 书 (第2套卷) 工位号:______________ 第一部分 竞赛须知 一、竞赛要求 1、正确使用工具,操作安全规范; 2、竞赛过程中如有异议,可向现场考评人员反映,不得扰乱赛场秩序; 3、遵守赛场纪律,尊重考评人员,…...
Go 接口:Go中最强大的魔法,接口应用模式或惯例介绍
Go 接口:Go中最强大的魔法,接口应用模式或惯例介绍 文章目录 Go 接口:Go中最强大的魔法,接口应用模式或惯例介绍一、前置原则二、一切皆组合2.1 一切皆组合2.2 垂直组合2.2.1 第一种:通过嵌入接口构建接口2.2.2 第二种:通过嵌入接…...
Vue3全局共享数据
目录 1,Vuex2,provide & inject2,global state4,Pinia5,对比 1,Vuex vue2 的官方状态管理器,vue3 也是可以用的,需要使用 4.x 版本。 相对于 vuex3.x,有两个重要变…...
openai自定义API操作 API 返回值说明
custom-自定义API操作 openai.custom 公共参数 名称类型必须描述keyString是调用key(获取测试key)secretString是调用密钥api_nameString是API接口名称(包括在请求地址中)[item_search,item_get,item_search_shop等]cacheStrin…...
jsp基本表格和简单算法表格
基本表格; <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd…...
在线存储系统源码 网盘网站源码 云盘系统源码
Cloudreve云盘系统源码-支持本地储存和对象储存,界面美观 云盘系统安装教程 测试环境:PHP7.1 MYSQL5.6 Apache 上传源码到根目录 安装程序: 浏览器数据 http://localhost/CloudreveInstallerlocalhost更换成你的网址 安装完毕 记住系统默认的账号密码 温馨提示:如果默认…...
线性代数(六)| 二次型 标准型转换 正定二次型 正定矩阵
文章目录 1. 二次型化为标准型1.1 正交变换法1.2 配方法 2 . 正定二次型与正定矩阵 1. 二次型化为标准型 和第五章有什么样的联系 首先上一章我们说过对于对称矩阵,一定存在一个正交矩阵Q,使得$Q^{-1}AQB $ B为对角矩阵 那么这一章中,我们…...
从电容到内存条:手把手拆解一颗DRAM芯片的内部架构与工作流程
从电容到内存条:手把手拆解一颗DRAM芯片的内部架构与工作流程 当你双击电脑桌面上的程序图标时,操作系统会从硬盘加载程序到内存条中运行——这个看似简单的动作背后,隐藏着一场精密的电荷舞蹈。作为现代计算机的核心部件,DRAM&am…...
别再盲目memcpy!嵌入式C中模型权重加载的4种内存对齐误用,已致3起量产固件崩溃
更多请点击: https://intelliparadigm.com 第一章:嵌入式C中模型权重加载的内存对齐本质与危害全景 内存对齐的本质:硬件访问契约 在ARM Cortex-M系列或RISC-V嵌入式平台中,CPU对非对齐地址执行32位读写会触发硬故障(…...
英雄联盟客户端个性化定制:5分钟打造你的专属游戏界面
英雄联盟客户端个性化定制:5分钟打造你的专属游戏界面 【免费下载链接】LeaguePrank 项目地址: https://gitcode.com/gh_mirrors/le/LeaguePrank 还在为英雄联盟客户端千篇一律的界面感到乏味吗?想让你的游戏资料页和在线状态展现独特个性吗&…...
019_数字孪生AI之智慧燃气:其概念,其实现原理,其适用的场景,常见的应用,以及未来布局的产业和市场,以及
数字孪生AI赋能智慧燃气:从原理到实战的全景指南 引言 想象这样一个场景:深夜,某老旧小区。传统模式下,一个微弱的燃气泄漏可能数小时甚至数天都未被察觉,直到有居民闻到异味才报警。随后,抢修队需要翻阅…...
如何快速使用WebPlotDigitizer:从图表中提取数据的完整指南
如何快速使用WebPlotDigitizer:从图表中提取数据的完整指南 【免费下载链接】WebPlotDigitizer Computer vision assisted tool to extract numerical data from plot images. 项目地址: https://gitcode.com/gh_mirrors/we/WebPlotDigitizer 还在为从论文图…...
神经网络常见层Numpy封装参考(4):优化器
目录前置层优化器SGD优化器Adam优化器测试演示完整代码下载 :神经网络常见层Numpy封装参考 - 常见层 前置层 - 神经网络常见层Numpy封装参考(1):损失层 - 神经网络常见层Numpy封装参考(2):线性…...
BrainScaleS-2神经形态计算系统架构与FPGA互连设计
1. BrainScaleS-2多芯片系统概述神经形态计算作为类脑智能研究的重要方向,其核心目标是通过硬件模拟生物神经系统的信息处理机制。与传统冯诺依曼架构相比,神经形态系统在处理时空稀疏信号时展现出显著的能效优势。BrainScaleS-2(BSS-2&#…...
别再为10G UDP发愁了!手把手教你用Xilinx 10G/25G Ethernet Subsystem IP核搭建FPGA网络栈(附12套工程源码)
10G UDP通信实战:基于Xilinx UltraScale架构的FPGA网络栈开发指南 第一次接触10G以太网开发时,我被那些闪烁的SFP光模块和复杂的协议栈配置搞得晕头转向。直到在实验室熬了三个通宵后,才终于让FPGA开发板与PC之间稳定传输了第一个数据包。这段…...
各区县路网密度数据(2013-2023年)
01、数据简介路网密度是某区域内的道路总长度与该区域总面积的比值,是特定范围内具有不同功能、等级和区位的道路,以一定的密度和适当的形式组成的网络系统结构。路网密度是城市交通系统中的重要指标之一,它反映了城市道路网的发展规模和供给…...
西安AI智能获客
在西安这片硬科技企业星罗棋布的创新沃土上,西安投肯未来科技有限公司正以AI为笔,在企业服务领域书写着数字化获客的全新答卷。作为本土AI智能营销赛道的新锐力量,这家扎根丝路起点的科技公司,瞄准传统获客模式成本高、效率低、精…...
