LeetCode热题100 腐烂的橘子
题目描述在给定的 m x n 网格 grid 中每个单元格可以有以下三个值之一值 0 代表空单元格值 1 代表新鲜橘子值 2 代表腐烂的橘子。每分钟腐烂的橘子 周围 4 个方向上相邻 的新鲜橘子都会腐烂。返回 直到单元格中没有新鲜橘子为止所必须经过的最小分钟数。如果不可能返回 -1 。示例 1输入grid [[2,1,1],[1,1,0],[0,1,1]]输出4示例 2输入grid [[2,1,1],[0,1,1],[1,0,1]]输出-1解释左下角的橘子第 2 行 第 0 列永远不会腐烂因为腐烂只会发生在 4 个方向上。示例 3输入grid [[0,2]]输出0解释因为 0 分钟时已经没有新鲜橘子了所以答案就是 0 。提示m grid.lengthn grid[i].length1 m, n 10grid[i][j] 仅为 0、1 或 2思路进行多源广度优先搜索多个起点视为同一层。代码classSolution{public:// 定义四个方向intdx[4]{1,-1,0,0},dy[4]{0,0,1,-1};intorangesRotting(vectorvectorintgrid){// 分钟数intres0;// 新鲜橘子个数intcnt0;// 存储烂橘子的位置queuearrayint,2q;// 获取矩阵边界intngrid.size(),mgrid[0].size();for(inti0;in;i){for(intj0;jm;j){if(grid[i][j]1)cnt;elseif(grid[i][j]2){q.push({i,j});grid[i][j]0;}}}// 进行层次遍历intqzq.size();while(cnt!q.empty()){auto[x,y]q.front();q.pop();--qz;for(inti0;i4;i){intxxxdx[i],yyydy[i];if(xx0xxnyy0yymgrid[xx][yy]1){--cnt;grid[xx][yy]0;q.push({xx,yy});}}// 每层结束或者全部腐烂, resif(qz!0cnt0){res;}elseif(qz0){res;qzq.size();}}// 返回分钟数if(cnt)return-1;elsereturnres;}};

相关新闻

LeetCode热题100 岛屿数量

LeetCode热题100 岛屿数量

题目描述 给你一个由 ‘1’(陆地)和 ‘0’(水)组成的的二维网格,请你计算网格中岛屿的数量。 岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。 此外,你可以假…

2026/7/3 11:47:37 阅读更多 →
高达扭蛋机小程序|开发全攻略

高达扭蛋机小程序|开发全攻略

高达扭蛋机小程序|开发全攻略 深度还原了高达扭蛋的沉浸式体验,从机甲立绘到抽卡音效,每一处细节都拉满。 🌟 核心功能亮点 沉浸式 UI:科技感十足的机甲舱界面,搭配高清高达立绘,视觉冲击感拉满…

2026/5/17 12:11:18 阅读更多 →
RS2227XN芯片实战:如何用MSOP10封装打造USB2.0信号切换神器(附电路图)

RS2227XN芯片实战:如何用MSOP10封装打造USB2.0信号切换神器(附电路图)

RS2227XN芯片实战:如何用MSOP10封装打造USB2.0信号切换神器(附电路图) 作为一名硬件工程师,你是否曾为项目中的USB接口复用问题而头疼?比如,一个USB Type-C接口需要同时支持数据传输和设备充电,…

2026/7/2 23:36:46 阅读更多 →

最新新闻

IDEA中JDK编译版本不匹配?97%开发者忽略的4个隐蔽配置层级(含IntelliJ 2023.3+最新验证)

IDEA中JDK编译版本不匹配?97%开发者忽略的4个隐蔽配置层级(含IntelliJ 2023.3+最新验证)

更多请点击: https://codechina.net 第一章:JDK编译版本不匹配的典型现象与危害 当Java源代码使用高版本JDK编译(如JDK 17),却在低版本JRE(如JRE 8)上运行时,会触发典型的版本兼容性…

2026/7/3 11:47:54 阅读更多 →
Java智能地址解析:3分钟从混乱文本到结构化数据的终极方案

Java智能地址解析:3分钟从混乱文本到结构化数据的终极方案

Java智能地址解析:3分钟从混乱文本到结构化数据的终极方案 【免费下载链接】address-parse Java 版智能解析收货地址 项目地址: https://gitcode.com/gh_mirrors/addr/address-parse 在电商、物流、CRM等系统中,处理用户输入的地址信息一直是个令…

2026/7/3 11:47:54 阅读更多 →
大模型编程入门:小白也能轻松掌握的AI Coding实战指南(收藏版)

大模型编程入门:小白也能轻松掌握的AI Coding实战指南(收藏版)

本文详细介绍了AI Coding的四种不同形态,重点讲解了L3本地AI Coding工具的Agent模式。作者以自身经历分享如何从抗拒到熟练运用AI Coding Agent,并提供了实用的使用方法和质量守卫策略。文章强调AI Coding是软件工程师的生存技能,鼓励大家积极…

2026/7/3 11:47:54 阅读更多 →
界面控件DevExpress WinForms v26.1新版亮点 - 皮肤更新、面板功能增强

界面控件DevExpress WinForms v26.1新版亮点 - 皮肤更新、面板功能增强

DevExpress WinForms控件包含了190多个Windows Forms控件和UI库,能帮助开发者提供为Windows Forms平台创建具有强大影响力的软件解决方案所需的组件,最新版本支持.NET 10。 在接下来的系列文章中,我将为大家一一介绍DevExpress WinForms v26…

2026/7/3 11:43:52 阅读更多 →
Kimi-K2.5本地部署全指南:MoE大模型在24GB显存上的硬核落地

Kimi-K2.5本地部署全指南:MoE大模型在24GB显存上的硬核落地

1. 项目概述:当SOTA级大模型真正“落进”你的硬盘里Kimi-K2.5本地部署这件事,我从去年底第一次在Hugging Face上看到unsloth/Kimi-K2.5-GGUF仓库时就盯上了。不是因为标题里写的“24G显存可跑”有多吸睛,而是因为它背后那个被反复验证却极少落…

2026/7/3 11:43:52 阅读更多 →
Sunshine游戏串流完整指南:从零开始搭建你的私人云游戏平台

Sunshine游戏串流完整指南:从零开始搭建你的私人云游戏平台

Sunshine游戏串流完整指南:从零开始搭建你的私人云游戏平台 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一款开源免费的自托管游戏串流服务器&#xff0c…

2026/7/3 11:41:52 阅读更多 →

日新闻

Nginx防御TLS重协商攻击实战:从原理到配置与监控

Nginx防御TLS重协商攻击实战:从原理到配置与监控

1. 项目概述:为什么TLS重协商攻击至今仍需警惕十多年前的CVE-2011-1473,一个关于TLS/SSL协议重协商机制的漏洞,现在提起来还有必要吗?很多运维和开发朋友可能会觉得,这都老掉牙了,现代服务器和客户端不都默…

2026/7/3 0:03:59 阅读更多 →
华为防火墙双通道远程管理实战:Web与SSH配置详解

华为防火墙双通道远程管理实战:Web与SSH配置详解

1. 项目概述:为什么需要双通道远程管理防火墙?在任何一个稍具规模的企业网络里,防火墙都是那个默默守护在边界的关键角色。作为网络工程师,我们不可能每次都跑到机房,插上console线去配置它。远程管理能力,…

2026/7/3 0:03:59 阅读更多 →
AD74413R与PIC18F65K40的高精度工业数据采集方案

AD74413R与PIC18F65K40的高精度工业数据采集方案

1. 项目概述:AD74413R与PIC18F65K40的协同工作在工业自动化和精密测量领域,同时实现高精度模数转换(ADC)和数模转换(DAC)功能是许多复杂系统的核心需求。AD74413R作为一款四通道可配置模拟输入/输出器件,与PIC18F65K40微控制器的组合&#xf…

2026/7/3 0:05:59 阅读更多 →

周新闻

月新闻