542.01 矩阵
【LetMeFly】542.01 矩阵
力扣题目链接:https://leetcode.cn/problems/01-matrix/
给定一个由 0
和 1
组成的矩阵 mat
,请输出一个大小相同的矩阵,其中每一个格子是 mat
中对应位置元素到最近的 0
的距离。
两个相邻元素间的距离为 1
。
示例 1:
输入:mat = [[0,0,0],[0,1,0],[0,0,0]] 输出:[[0,0,0],[0,1,0],[0,0,0]]
示例 2:
输入:mat = [[0,0,0],[0,1,0],[1,1,1]] 输出:[[0,0,0],[0,1,0],[1,2,1]]
提示:
m == mat.length
n == mat[i].length
1 <= m, n <= 104
1 <= m * n <= 104
mat[i][j] is either 0 or 1.
mat
中至少有一个0
方法一:广度优先搜索
首先遍历原始矩阵,找到所有的0,将其位置入队。
接着在队列不为空时,不断出队一个位置,并判断这个位置的上下左右是否被遍历过。
如果还没有被遍历过,那么就将新的位置入队。并将地图中新的位置的值修改为“出队位置的值 + 1”
原理:
所有的原始的0最终结果都是0。广度优先搜索就是在所有的“0”的位置中,走一步。这一步所到的位置就是“1”步能到达的位置。同理,“1”经过一步到达的位置就是“2”。最先到达的就是步数最少的。
- 时间复杂度$O(nm)$
- 空间复杂度$O(nm)$
AC代码
C++
1 |
|
同步发文于CSDN,原创不易,转载请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/128175163
542.01 矩阵
https://blog.letmefly.xyz/2022/12/04/LeetCode 0542.01矩阵/