当前位置: 首页 > java >正文

力扣HOT100之图论:994. 腐烂的橘子


这道题属于是BFS的模板题,很像病毒扩散的过程,之前在刷代码随想录的时候也刷过类似的题目,具体的BFS代码写法可以参照这篇博客我们需要统计出腐烂至全地图时所需的最少扩散次数,当然也存在有的橘子无法被腐烂的情况,因此我们需要先统计初始状态下的新鲜橘子个数,每当扩散一次,被扩散的新鲜橘子就变成腐烂橘子,并将新鲜的橘子数减去对应的数量,当扩散结束后,如果新鲜的橘子数量大于0,则说明无法腐烂所有的橘子,我们直接返回-1,否则就直接返回扩散的轮数。由于初始状态下的腐烂橘子可能不止一个,我们需要将初始状态下的腐烂橘子坐标添加到队列中,然后再开始扩散。扩散过程需要用两重while循环来实现,外层while循环每循环一次,就代表扩散了一次,内层while循环每循环一次,就是从当前的其中一个腐烂橘子向四周扩散了一次,被腐烂的橘子将加入队列,但是不会参与内层循环的过程,因为在内层循环腐烂的橘子并不是本轮的初始腐烂橘子,应当在下一次外层while循环中进行扩散。

class Solution {
public:int orangesRotting(vector<vector<int>>& grid) {int result = 0;//定义4个方向vector<vector<int>> dirs ={{0, 1},      //向右{0, -1},     //向左{1, 0},      //向下{-1, 0}      //向上};int m = grid.size(), n = grid[0].size();  //m行n列int fresh = 0;  //统计初始状态下新鲜橘子的数量queue<pair<int, int>> My_Queue;  //用于存放网格坐标//统计新鲜的橘子数量和腐烂橘子的初始位置for(int i = 0; i < m; i++){for(int j = 0; j < n; j++){if(grid[i][j] == 1) fresh++;if(grid[i][j] == 2)My_Queue.push({i, j});}}while(fresh > 0 && !My_Queue.empty()){int size = My_Queue.size();while(size > 0){pair<int, int> current = My_Queue.front();My_Queue.pop();size--;for(auto dir : dirs){int next_x = current.first + dir[0];int next_y = current.second + dir[1];if((next_x < 0 || next_x >= m) || (next_y < 0 || next_y >= n))continue;   //越界访问直接跳过if(grid[next_x][next_y] == 1){grid[next_x][next_y] = 2;fresh--;My_Queue.push({next_x, next_y});}}}result++;}return fresh > 0 ? -1 : result;}
};
http://www.xdnf.cn/news/8412.html

相关文章:

  • 二、详细解释OpenGL图形管线中顶点处理阶段的工作原理
  • day57—快速(选择/排序)—数组中的第 K 个最大元素(LeetCode-215)
  • 国家网络身份认证公共服务管理办法
  • nginx配置跨域请求,后台不用配置啦,完美
  • vue 水印组件
  • 【Dv3Admin】插件 dv3admin_chatgpt 优化支持多种启动方式实现SSE效果
  • QT之巧用对象充当信号接收者
  • Linux进程 线程 进程间通信 IPC——管道
  • 全国青少年信息素养大赛-python编程—省赛真题—卡牌游戏
  • Redis配置文件详解
  • 树 Part 10
  • JFace中MVC的表的单元格编辑功能的实现
  • Datawhale_PyPOTS_task6
  • 【安全攻防与漏洞​】​​HTTPS中的常见攻击与防御​​
  • 机器人强化学习入门学习笔记(三)
  • 洛谷 P1800 software(DP+二分)【提高+/省选−】
  • 三步快速部署一个本地Windows/Linux大语言模型ChatGLM(环境配置+权重下载+运行)
  • AI架构分层原则
  • Stack主题遇到的问题
  • C# WinForm应用程序多语言实现全面指南
  • deepseek组合使用
  • 测试关键点
  • 【Kafka】编写消费者开发模式时遇到‘未解析的引用‘SIGUSR1’’
  • 掌握递归:编程中的优雅艺术
  • 精益数据分析(79/126):从黏性到爆发——病毒性增长的三种形态与核心指标解析
  • Swagger、Springfox、Springdoc-openapi 到底是什么关系
  • 使用 GPUStack 纳管摩尔线程 GPU 进行大语言模型和文生图模型的推理
  • ASPICE认证 vs. 其他标准:汽车软件开发的最优选择
  • C# UDP协议:核心原理、高效实现与实战进阶指南​
  • 2025语音语聊系统源码开发深度解析:WebRTC与AI降噪技术如何重塑语音社交体验