美文网首页
994.腐烂的橘子

994.腐烂的橘子

作者: 最尾一名 | 来源:发表于2020-03-04 11:00 被阅读0次

原题

https://leetcode-cn.com/problems/rotting-oranges/

解题思路

典型的深度优先搜索。

我们先遍历一遍,将所有腐烂的橘子的位置放入队列 {x: 腐烂橘子的横坐标, y: 腐烂橘子的纵坐标, min: 该橘子腐烂需要的时间},并给新鲜的橘子计数。

当队列中有元素时,取出队列中的第一个元素 current,检查 current 的上下左右四个位置是否有新鲜的橘子,如果有的话:
将新鲜橘子的位置入队 {x: 腐烂橘子的横坐标, y: 腐烂橘子的纵坐标, min: current + 1},并且更新当前的最大时间。

当队列中没有元素时,检查 cnt 是否为 0,若不为零则返回 -1, 否则返回当前的最大时间。

代码

/**
 * @param {number[][]} grid
 * @return {number}
 */
var orangesRotting = function(grid) {
    const m = grid.length, n = grid[0].length;
    const queue = new Array(), offset = [{x: -1, y: 0}, {x: 1, y: 0}, {x: 0, y: -1}, {x: 0, y: 1}];
    let cnt = 0, res = 0;
    for (let i = 0; i < m; ++i) {
        for (let j = 0; j < n; ++j) {
            if (grid[i][j] === 1) {
                ++cnt;
                continue;
            }
            if (grid[i][j] === 2) {
                queue.push({x: i, y: j, min: 0});
            }
        }
    }
    while(queue.length) {
        const current = queue.shift();
        for (let i = 0; i < 4; ++i) {
            if ((offset[i].x+current.x >= 0) 
            && (offset[i].y+current.y >= 0) 
            && (offset[i].x+current.x < m) 
            && (offset[i].y+current.y < n) 
            && grid[offset[i].x+current.x][offset[i].y+current.y] === 1) {
                grid[offset[i].x+current.x][offset[i].y+current.y] = 2;
                --cnt;
                queue.push({x: offset[i].x+current.x, y: offset[i].y+current.y, min: current.min + 1});
                res = Math.max(res, current.min + 1);
            }
        }
    }
    return cnt ? -1 : res;
};

复杂度

  • 时间复杂度 O(MN)
  • 空间复杂度 O(MN)

相关文章

  • 994.腐烂的橘子

    原题 https://leetcode-cn.com/problems/rotting-oranges/ 解题思路...

  • 994.腐烂的橘子

    由题目我们可以知道每分钟每个腐烂的橘子都会使上下左右相邻的新鲜橘子腐烂,这其实是一个模拟广度优先搜索的过程。所谓广...

  • queue:994.腐烂的橘子

    考点:队列 动态的遍历queue 遍历queue的同时会追加元素 广度优先搜索算法

  • LeetCode 994. 腐烂的橘子

    在给定的网格中,每个单元格可以有以下三个值之一: 值 0 代表空单元格; 值 1 代表新鲜橘子; 值 2 代表腐烂...

  • Leetcode 994. 腐烂的橘子

    题目描述 在给定的网格中,每个单元格可以有以下三个值之一: 值 0 代表空单元格; 值 1 代表新鲜橘子; 值 2...

  • 994. 腐烂的橘子(Python)

    难度:★★★☆☆类型:数组方法:宽度优先搜索,队列 题目 力扣链接请移步本题传送门[https://leetcod...

  • 994. 腐烂的橘子-广度优先搜索BFS

    题目:https://leetcode-cn.com/problems/rotting-oranges/ 我的方法...

  • 腐烂的橘子

    题目: 题目的理解: 分几个小步骤思考: 1. 网格中是否还有正常的橘子。 2. 网格中坏橘子的位置。 3. 怀橘...

  • 542. 01 矩阵、1162. 地图分析、994. 腐烂的橘子

    本次的三道题都用了多源点BFS的方法,关于什么是多源点BFS呢,就是求很多个起点到一个终点的关系,就将终点入队,反...

  • 正在慢慢腐烂的橘子

    把一个稍腐烂的橘子包上华丽的包装 放在冰箱里 你看不见它还在慢慢腐烂的身体 却暗自欣赏它上了包装的外边

网友评论

      本文标题:994.腐烂的橘子

      本文链接:https://www.haomeiwen.com/subject/qvfmlhtx.html