首页 分享 Leetcode 994:腐烂的橘子(超详细的解法!!!)

Leetcode 994:腐烂的橘子(超详细的解法!!!)

来源:花匠小妙招 时间:2024-12-29 17:25

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

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

每分钟,任何与腐烂的橘子(在 4 个正方向上)相邻的新鲜橘子都会腐烂。

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

示例 1:

输入:[[2,1,1],[1,1,0],[0,1,1]] 输出:4 12

示例 2:

输入:[[2,1,1],[0,1,1],[1,0,1]] 输出:-1 解释:左下角的橘子(第 2 行, 第 0 列)永远不会腐烂,因为腐烂只会发生在 4 个正向上。 123

示例 3:

输入:[[0,2]] 输出:0 解释:因为 0 分钟时已经没有新鲜橘子了,所以答案就是 0 。 123

提示:

1 <= grid.length <= 101 <= grid[0].length <= 10grid[i][j] 仅为 0、1 或 2

解题思路

这个问题类似于岛屿问题,我们只需将所有的烂橘子的坐标存放到一个队列里面,然后通过BFS将附近的新鲜橘子腐蚀即可。

class Solution: def orangesRotting(self, grid: List[List[int]]) -> int: r, c =len(grid), len(grid[0]) d = [0, 1, 0, -1, 0] q = [] step = cnt = 0 for i in range(r): for j in range(c): if grid[i][j] == 2: q.append([i, j]) if grid[i][j] == 1: cnt += 1 while q: if cnt == 0: return step n = len(q) for _ in range(n): x, y = q.pop(0) for i in range(4): nx, ny = x + d[i], y + d[i + 1] if 0 <= nx < r and 0 <= ny < c and grid[nx][ny] == 1: cnt -= 1 q.append([nx, ny]) grid[nx][ny] = 2 step += 1 return step if cnt == 0 else -1

123456789101112131415161718192021222324252627

我将该问题的其他语言版本添加到了我的GitHub Leetcode

如有问题,希望大家指出!!!

相关知识

基于机器学习的花卉识别系统
时间序列分解 季节调整 eviews10步骤
LeetCode 1
loess去季节性趋势 公式
LeetCode
柱花草炭疽菌致病力丧失突变菌株994的T
备考压力缓解法
Leetcode 题解
兰花的养殖方法(超详细入门篇)
花花酱leetcode 题目——搜索专题

网址: Leetcode 994:腐烂的橘子(超详细的解法!!!) https://www.huajiangbk.com/newsview1356985.html

所属分类:花卉
上一篇: 文玩人家里的东西别乱动!什么零食
下一篇: 为什么橘子放久了吃起来有腐烂的味

推荐分享