50.腐烂的橘子

1.题目描述

在给定的 m x n 网格 grid 中,每个单元格可以有以下三个值之一:

  • 0 代表空单元格;
  • 1 代表新鲜橘子;
  • 2 代表腐烂的橘子。

每分钟,腐烂的橘子 周围 4 个方向上相邻 的新鲜橘子都会腐烂。

返回 直到单元格中没有新鲜橘子为止所必须经过的最小分钟数。如果不可能,返回 -1

2.题目思路

这是通用的BFS思路,关于图和树都可以用,如二叉树的右视图,计算二叉树的层数等题目

python 复制代码
depth = 0 # 记录遍历到第几层
while queue 非空:
    depth++
    n = queue 中的元素个数
    循环 n 次:
        node = queue.pop()
        for node 的所有相邻结点 m:
            if m 未访问过:
                queue.push(m)

3.代码及详细注释

cpp 复制代码
class Solution {
public:
    int orangesRotting(vector<vector<int>>& grid) {
        //1.计算腐烂橘子和好橘子,并把腐烂橘子全都入队表示0min时刻
        int count=0;
        queue<pair<int,int>> q;
        int M = grid.size();
        int N = grid[0].size();
        for(int i = 0;i<=M-1;i++){
            for(int j = 0;j<=N-1;j++){
                if(grid[i][j]==1){
                    count++;//好橘子总数
                }
                else if(grid[i][j]==2){
                    q.push({i,j});
                }
            }
        }
        if(count==0) return 0;
        int round = 0;//返回的结果
        int fresh = 0;
        while(fresh < count &&!q.empty()){//注意这个条件,最后个新鲜橘子即将被腐烂的状态,grid[i][j]=2,fresh ==count了,然后入队列被腐烂的橘子,队列不为空,还会进行一次判断.
            int n = q.size();
            round++;
            while(n>0){
                int i = q.front().first;
                int j = q.front().second;
                q.pop();
                if(i-1>=0 &&grid[i-1][j]==1){//top
                  //污染橘子
                  fresh++;
                  grid[i-1][j]=2;
                  q.push({i-1,j});
                }
                if(i+1<=M-1 && grid[i+1][j]==1){//down
                    fresh++;
                    grid[i+1][j]=2;
                    q.push({i+1,j});
                }
                if(j-1>=0 && grid[i][j-1]==1){//left
                    fresh++;
                    grid[i][j-1]=2;
                    q.push({i,j-1});
                }
                if(j+1<=N-1 && grid[i][j+1]==1){//right
                    fresh++;
                    grid[i][j+1]=2;
                    q.push({i,j+1});
                }
                n--;
            }
        }
        if(count-fresh!=0){
            return -1;
        }
        return round;
    }
};
相关推荐
卷福同学1 天前
QClaw内测体验,能用微信指挥AI干活了
人工智能·算法·ai编程
sali-tec1 天前
C# 基于OpenCv的视觉工作流-章34-投影向量
图像处理·人工智能·opencv·算法·计算机视觉
xiaoye-duck1 天前
《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂
数据结构·c++·算法·递归
Eward-an1 天前
【算法竞赛/大厂面试】盛最多水容器的最大面积解析
python·算法·leetcode·面试·职场和发展
山栀shanzhi1 天前
归并排序(Merge Sort)原理与实现
数据结构·c++·算法·排序算法
阿豪学编程1 天前
LeetCode438: 字符串中所有字母异位词
算法·leetcode
Trouvaille ~1 天前
【递归、搜索与回溯】专题(七):FloodFill 算法——勇往直前的洪水灌溉
c++·算法·leetcode·青少年编程·面试·蓝桥杯·递归搜索回溯
地平线开发者1 天前
征程 6P codec decoder sample
算法·自动驾驶
地平线开发者1 天前
征程 6X Camera 接入数据评估
算法·自动驾驶
Storynone1 天前
【Day23】LeetCode:455. 分发饼干,376. 摆动序列,53. 最大子序和
python·算法·leetcode