LeetCode hot100-52-G

java 复制代码
994. 腐烂的橘子
在给定的 m x n 网格 grid 中,每个单元格可以有以下三个值之一:

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

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

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

官方答案看不懂,没注释。找到个好一点能看懂的解答

https://leetcode.cn/problems/rotting-oranges/solutions/2773461/duo-yuan-bfsfu-ti-dan-pythonjavacgojsrus-yfmh/?envType=study-plan-v2\&envId=top-100-liked

代码是这个网址评论区的

思路bfs。将所有腐烂的句子入队列。然后每次循环都将队列弹出至空,并将这次传染的所有橘子入队列。也就是将同一分钟腐烂的同时出队,下一分钟腐烂的橘子同时入队。很像二叉树层次遍历的感觉。

最初ans=-1是因为最后一次腐烂完的橘子入队后,还需要循环一次把队列清空,这时候ans+1了,但是它清空之后没有能腐烂的橘子了,所以多加了1,最初就用的-1. 因为这个-1的存在还需要Math.max(res, 0),最初就没有腐烂的橘子时ans一直是-1,其实答案是0.

java 复制代码
class Solution {
    static int[][] changes = new int[][] { { -1, 0 }, { 1, 0 }, { 0, 1 }, { 0, -1 } };

    public int orangesRotting(int[][] grid) {
        int m = grid.length;
        int n = grid[0].length;

        // 坏橘子队列 [i,j]
        Deque<int[]> queue = new ArrayDeque<>();
        // 好橘子数量
        int goodCount = 0;
        // 遍历所有橘子
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                int x = grid[i][j];
                if (x == 2) {
                    queue.add(new int[] { i, j });
                } else if (x == 1) {
                    goodCount++;
                }
            }
        }
        int res = -1;
        // BFS遍历
        while (!queue.isEmpty()) {
            int size = queue.size();
            while (size-- > 0) {
                int[] p = queue.poll();
                int x = p[0];
                int y = p[1];

                for (int i = 0; i < changes.length; i++) {
                    int nx = x + changes[i][0];
                    int ny = y + changes[i][1];
                    // 向四周污染
                    if (nx >= 0 && nx <= m - 1 && ny >= 0 && ny <= n - 1 && grid[nx][ny] == 1) {
                        grid[nx][ny] = 2;
                        // 将新的坏橘子放入队列
                        queue.add(new int[] { nx, ny });
                        goodCount--;
                    }
                }
            }
            res++;
        }
        return goodCount == 0 ? Math.max(res, 0) : -1;
    }
}
相关推荐
hsling松子1 小时前
使用PaddleHub智能生成,献上浓情国庆福
人工智能·算法·机器学习·语言模型·paddlepaddle
dengqingrui1232 小时前
【树形DP】AT_dp_p Independent Set 题解
c++·学习·算法·深度优先·图论·dp
C++忠实粉丝2 小时前
前缀和(8)_矩阵区域和
数据结构·c++·线性代数·算法·矩阵
ZZZ_O^O2 小时前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King3 小时前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家3 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain3 小时前
算法 | 位运算(哈希思想)
算法
Kalika0-05 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
sp_fyf_20245 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-02
人工智能·神经网络·算法·计算机视觉·语言模型·自然语言处理·数据挖掘
我是哈哈hh7 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝