Leetcode 994:腐烂的橘子(超详细的解法!!!)
在给定的网格中,每个单元格可以有以下三个值之一:
值 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
上一篇: 文玩人家里的东西别乱动!什么零食 |
下一篇: 为什么橘子放久了吃起来有腐烂的味 |
推荐分享

- 1君子兰什么品种最名贵 十大名 4012
- 2世界上最名贵的10种兰花图片 3364
- 3花圈挽联怎么写? 3286
- 4迷信说家里不能放假花 家里摆 1878
- 5香山红叶什么时候红 1493
- 6花的意思,花的解释,花的拼音 1210
- 7教师节送什么花最合适 1167
- 8勿忘我花图片 1103
- 9橄榄枝的象征意义 1093
- 10洛阳的市花 1039