力扣---腐烂的橘子
题目:

bfs思路:
感觉bfs还是很容易想到的,首先定义一个双端队列(队列也是可以的~),如果值为2,则入队列,我这里将队列中的元素定义为pair<int,int>。第一个int记录在数组中的位置,即将二维数组映射到一维数组。没明白的小伙伴可以先看看力扣hot---岛屿数量-CSDN博客。第二个int记录这个橘子第几分钟被感染。最后取最大的分钟就可以啦!(还要检查一下是否有没感染到的橘子,在橘子入队列的时候,记得将grid[x][y]改为2就可以记录橘子被感染了)
代码:
C++:
class Solution {
public:int p_x[4]={-1,1,0,0};int p_y[4]={0,0,-1,1};int orangesRotting(vector<vector<int>>& grid) {deque<pair<int,int>> q;int m=grid.size();int n=grid[0].size();int cnt=0;int res=0;//初始化qfor(int i=0;i<m;i++){for(int j=0;j<n;j++){if(grid[i][j]==2){q.push_back({i*n+j,cnt}); //把数组转换成1维,并且记录第几分钟}}}//开始腐烂while(!q.empty()){//popauto temp=q.front();q.pop_front();//腐烂四周int tempx=temp.first/n;int tempy=temp.first%n;int tempcnt=temp.second;//if(grid[tempx][tempy]==2){continue;}for(int k=0;k<4;k++){int x=tempx+p_x[k];int y=tempy+p_y[k];if(x>=0 && x<m && y>=0 && y<n){if(grid[x][y]==0||grid[x][y]==2){continue;}grid[x][y]=2;q.push_back({x*n+y,tempcnt+1});cnt=max(cnt,tempcnt+1);}}}for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(grid[i][j]==1){return -1;}}}return cnt;}
};
Python代码就不附啦,因为和今天发布的力扣---接雨水---单调队列-CSDN博客Python代码很像哦
相关文章:
力扣---腐烂的橘子
题目: bfs思路: 感觉bfs还是很容易想到的,首先定义一个双端队列(队列也是可以的~),如果值为2,则入队列,我这里将队列中的元素定义为pair<int,int>。第一个int记录在数组中的位…...
【开源物联网平台】FastBee使用EMQX5.0接入步骤
🌈 个人主页:帐篷Li 🔥 系列专栏:FastBee物联网开源项目 💪🏻 专注于简单,易用,可拓展,低成本商业化的AIOT物联网解决方案 目录 一、将java内置mqtt broker切换成EMQX5…...
【数学】【组合数学】1830. 使字符串有序的最少操作次数
作者推荐 视频算法专题 本博文涉及知识点 数学 组合数学 LeetCode1830. 使字符串有序的最少操作次数 给你一个字符串 s (下标从 0 开始)。你需要对 s 执行以下操作直到它变为一个有序字符串: 找到 最大下标 i ,使得 1 < i…...
算法(数据结构)面试问题准备 二分法/DFS/BFS/快排
一、算法概念题 1. 二分法 总结链接几种查找情况的模板另一个好记的总结总结:搜索元素两端闭,while带等,mid1,结束返-1 搜索边界常常左闭右开,while小于,mid看边界开闭,闭开,结束i…...
Unity3d C#实现文件(json、txt、xml等)加密、解密和加载(信息脱敏)功能实现(含源码工程)
前言 在Unity3d工程中经常有需要将一些文件放到本地项目中,诸如json、txt、csv和xml等文件需要放到StreamingAssets和Resources文件夹目录下,在程序发布后这些文件基本是对用户可见的状态,造成信息泄露,甚至有不法分子会利用这些…...
解释一下分库分表的概念和优缺点。如何设计一个高性能的数据库架构?
解释一下分库分表的概念和优缺点。 分库分表是数据库架构优化的常见手段,主要用于解决单一数据库或表在数据量增大、访问频率提高时面临的性能瓶颈和扩展性问题。 概念: 分库(Sharding-Database): 将原本存储在一个…...
功能强大使用简单的截图/贴图工具,PixPin
一、下载链接 PixPin 截图/贴图/长截图/文字识别/标注 | PixPin 截图/贴图/长截图/文字识别/标注 (pixpinapp.com) 二、功能 截图/贴图/长截图/文字识别/标注 三、安装教程 根据提示安装即可: 四、快捷键 1.软件自带快捷键(右击PixPin查看 )…...
机器学习周报第32周
目录 摘要Abstract一、文献阅读1.论文标题2.论文摘要3.论文背景4.论文方案4.1 多视角自注意力网络4.2 距离感知4.3 方向信息4.4 短语模式 二、self-attention 摘要 本周学习了多视角自注意力网络,在统一的框架下联合学习输入句子的不同语言学方面。具体来说&#x…...
人工智能|机器学习——DBSCAN聚类算法(密度聚类)
1.算法简介 DBSCAN(Density-Based Spatial Clustering of Applications with Noise)是一种基于密度的聚类算法,簇集的划定完全由样本的聚集程度决定。聚集程度不足以构成簇落的那些样本视为噪声点,因此DBSCAN聚类的方式也可以用于异常点的检测。 2.算法原…...
Excel F4键的作用
目录 一. 单元格相对/绝对引用转换二. 重复上一步操作 一. 单元格相对/绝对引用转换 ⏹ 使用F4键 如下图所示,B1单元格引用了A1单元格的内容。此时是使用相对引用,可以按下键盘上的F4键进行相对引用和绝对引用的转换。 二. 重复上一步操作 ⏹添加或删除…...
前端实现跨域的六种解决方法
本专栏是汇集了一些HTML常常被遗忘的知识,这里算是温故而知新,往往这些零碎的知识点,在你开发中能起到炸惊效果。我们每个人都没有过目不忘,过久不忘的本事,就让这一点点知识慢慢渗透你的脑海。 本专栏的风格是力求简洁…...
macOS上实现「灵动岛」效果
自从Apple iPhone推出了「灵动岛」功能后,用户们就被其优雅的设计和强大的功能所吸引。然而,作为macOS用户,我们一直在等待这一功能能够在我们的设备上实现。现在,随着新的应用程序的推出,我们终于可以在我们的Mac上体…...
幕译--本地字幕生成与翻译--Whisper客户端
幕译–本地字幕生成与翻译 本地离线的字幕生成与翻译,支持GPU加速。可免费试用,无次数限制 基于Whisper,希望做最好的Whisper客户端 功能介绍 本地离线,不用担心隐私问题支持GPU加速支持多种模型支持(中文、英语、日…...
链表基础知识详解
链表基础知识详解 一、链表是什么?1.链表的定义2.链表的组成3.链表的优缺点4.链表的特点 二、链表的基本操作1.链表的建立2.链表的删除3.链表的查找4.链表函数 一、链表是什么? 1.链表的定义 链表是一种物理存储单元上非连续、非顺序的存储结构…...
GPT-prompt大全
ChatGPT目前最强大的的工具是ChatGPT Plus,不仅训练数据更新到了2023年,而且还可以优先访问新功能。对于程序员来说,升级到ChatGPT Plus,将会带来更多的便利和效率提升。 根据 升级ChatGPT Plus保姆级教程,1分钟就可以…...
的发射点2
☞ 通用计算机启动过程 1️⃣一个基础固件:BIOS 一个基础固件:BIOS→基本IO系统,它提供以下功能: 上电后自检功能 Power-On Self-Test,即POST:上电后,识别硬件配置并对其进行自检,…...
深入揭秘Lucene:全面解析其原理与应用场景(一)
本系列文章简介: 本系列文章将深入揭秘Lucene,全面解析其原理与应用场景。我们将从Lucene的基本概念和核心组件开始,逐步介绍Lucene的索引原理、搜索算法以及性能优化策略。通过阅读本文,读者将会对Lucene的工作原理有更深入的了解…...
拿捏算法的复杂度
目录 前言 一:算法的时间复杂度 1.定义 2.简单的算法可以数循环的次数,其余需要经过计算得出表达式 3.记法:大O的渐近表示法 表示规则:对得出的时间复杂度的函数表达式,只关注最高阶,其余项和最高阶…...
C语言实战—猜数字游戏(涉及循环和少部分函数内容)
对于前面一些内容的总结 不妨跟着一起试试吧 折半查找算法(二分查找) 比如我买了一双鞋,你好奇问我多少钱,我说不超过300元。你还是好奇,你想知道到底多少,我就让 你猜,你会怎么猜?…...
#define MODIFY_REG(REG, CLEARMASK, SETMASK)
#define MODIFY_REG(REG, CLEARMASK, SETMASK) WRITE_REG((REG), (((READ_REG(REG)) & (~(CLEARMASK))) | (SETMASK))) 这个宏 MODIFY_REG 是在嵌入式编程中,它用于修改一个寄存器的特定位,而不影响其他位。这个宏接受三个参数ÿ…...
深入理解EtherCAT状态机:从IGH代码看伺服电机如何从‘上电’到‘使能’
深入解析EtherCAT状态机:从状态字到伺服控制的实战指南 当伺服电机在EtherCAT网络中无法正常使能时,许多工程师的第一反应往往是检查硬件连接或网络配置,却忽略了最核心的状态机逻辑。实际上,超过60%的伺服控制问题都源于对DS402状…...
GNSS定位质量分析实战:如何利用PPP-B2b提升GPS/BDS的PDOP与可视卫星数?
GNSS定位质量优化实战:PPP-B2b如何重塑多系统联合定位性能 当高精度定位成为自动驾驶、精准农业和地质监测等领域的基础需求时,GNSS系统的性能优化便成为工程师们必须面对的课题。北斗三号全球系统新增的PPP-B2b服务,为亚太区域用户提供了开…...
别再只调软件了!用STM32调PID,先检查这3个硬件坑(附MG513电机实测)
STM32电机PID调试避坑指南:硬件问题排查与MG513实战 调试PID控制器时,我们常常陷入反复调整参数的泥潭,却忽略了硬件层面的潜在问题。本文将揭示三个最容易被忽视的硬件陷阱,结合Wheeltec MG513编码电机的实际案例,帮助…...
Qwen3.5-9B嵌入式开发新思路:STM32项目智能代码生成
Qwen3.5-9B嵌入式开发新思路:STM32项目智能代码生成 1. 嵌入式开发的痛点与机遇 对于嵌入式开发者来说,STM32项目的开发过程往往伴随着大量重复性工作。从GPIO配置到定时器中断处理,从外设初始化到通信协议实现,这些基础代码占据…...
**工业4.0时代下基于Python的智能制造设备状态实时监控系统设计与实现**在工业
工业4.0时代下基于Python的智能制造设备状态实时监控系统设计与实现 在工业4.0浪潮席卷全球的背景下,传统制造业正加速向智能化、数字化转型。其中,设备状态实时监控作为智能工厂的核心环节之一,已成为提升生产效率、降低故障率的关键手段。…...
泛化能力基础:AI 适应新数据的关键
文章目录前言一、先搞懂:到底什么是AI泛化能力?1.1 用生活类比秒懂泛化1.2 学术定义(2026年标准表述)1.3 为什么2026年泛化比以往更重要?二、泛化的天敌:过拟合与欠拟合2.1 欠拟合:连作业都不会…...
StructBERT在网络安全中的应用:恶意邮件与钓鱼文本相似度识别
StructBERT在网络安全中的应用:恶意邮件与钓鱼文本相似度识别 你有没有想过,为什么有些钓鱼邮件明明看起来和之前的不太一样,却还是能被安全系统精准地揪出来?这背后,可能就藏着一个聪明的“文本侦探”——StructBERT…...
Rust的闭包中的实践最佳
Rust的闭包实践最佳指南 Rust的闭包是一种强大的工具,能够以简洁的方式捕获上下文并实现灵活的代码逻辑。闭包在函数式编程、异步任务处理和迭代器操作中扮演着重要角色。如何高效、安全地使用闭包,是许多开发者面临的挑战。本文将介绍Rust闭包的实践最…...
用户体验测试可用性与可访问性
用户体验测试:可用性与可访问性的核心实践 在数字化时代,产品能否成功往往取决于用户体验的优劣。可用性与可访问性作为用户体验的核心要素,直接影响用户对产品的满意度与忠诚度。可用性关注产品是否易于使用,而可访问性则确保所…...
Phi-4-mini-reasoning辅助Anaconda环境管理:依赖冲突的智能解决建议
Phi-4-mini-reasoning辅助Anaconda环境管理:依赖冲突的智能解决建议 1. 引言:Python开发者的依赖管理之痛 如果你经常使用Anaconda进行Python开发,一定遇到过这样的场景:当你满怀期待地运行conda install安装新包时,…...
