LeetCode:994腐烂的橘子

java 复制代码
class Solution {
    public int orangesRotting(int[][] grid) {
        int rows = grid.length;
        int cols = grid[0].length;

        //盛放腐烂橘子坐标
        Queue<int[]> queue = new LinkedList<>();
        //记录新鲜橘子数量
        int freshCount = 0;

        //遍历整个网格,将腐烂橘子放入队列同时统计新鲜数量
        for(int r = 0; r < rows; r++){
            for(int c = 0; c < cols; c++){
                if(grid[r][c] == 2){
                    queue.offer(new int[]{r,c});
                }else if(grid[r][c] == 1){
                    freshCount++;
                }
            }
        }

        if(freshCount == 0){
            return 0;
        }

        int minutes = 0;
        //上下左右移动的数组
        int[][] dirs = {{-1,0},{1,0},{0,-1},{0,1}};

        while(!queue.isEmpty() && freshCount > 0){
            minutes++;
            //当前队列中腐烂橘子数量
            int size = queue.size();

            for(int i = 0; i < size; i++){
                //取出腐烂橘子的坐标
                int[] zombie = queue.poll();
                int r = zombie[0];
                int c = zombie[1];

                //开始向四周橘子腐烂
                for(int[] dir : dirs){
                    int nextR = r + dir[0];
                    int nextC = c + dir[1];

                    if(nextR < 0 || nextR >= rows || nextC < 0 || nextC >= cols
                        || grid[nextR][nextC] != 1){
                        continue;
                    }

                    grid[nextR][nextC] = 2;
                    freshCount--;

                    queue.offer(new int[]{nextR,nextC});
                }
            }
        }
        return freshCount == 0 ? minutes : -1;
    }
}

解题思路:

定义一个盛放一维数组的队列,用于盛放腐烂的橘子;定义一个记录新鲜橘子数量的变量。

双层循环将腐烂橘子入队,同时记录新鲜橘子数量。

循环将腐烂橘子向上下左右四个方向扩散,同时设置边界条件。

新的腐烂橘子入队。

找连通块、算面积、数有几座岛,用DFS

求最短路径、求扩散层数、求最小时间,用BFS

相关推荐
JieE21210 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack2018 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树20 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
唐青枫1 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马1 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261351 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261351 天前
Java 打印 Word 文档:从基础打印到高级设置
java
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法