01 Matrix
Given an m x n
binary matrix mat
, return the distance of the nearest 0
for each cell.
The distance between two adjacent cells is 1
.
Example 1:
Input: mat = [[0,0,0],[0,1,0],[0,0,0]] Output: [[0,0,0],[0,1,0],[0,0,0]]
Example 2:
Input: mat = [[0,0,0],[0,1,0],[1,1,1]] Output: [[0,0,0],[0,1,0],[1,2,1]]
class Solution {
//把所有的0加入队列,所有的1设置为-1
//进行广度优先遍历
public int[][] updateMatrix(int[][] mat) {
Queue<int[]> queue = new LinkedList();
for (int i = 0; i < mat.length; i++) {
for (int j = 0; j < mat[0].length; j++) {
if (mat[i][j] == 0) {
queue.offer(new int[]{i, j});
} else {
mat[i][j] = -1;
}
}
}
int[] dy = {0, 0, -1, 1};
int[] dx = {-1, 1, 0, 0};
while (!queue.isEmpty()) {
int[] point = queue.poll();
int x = point[0];
int y = point[1];
for (int i = 0; i < 4; i++) {
int newX = x + dx[i];
int newY = y + dy[i];
if (newX >= 0 && newX < mat.length && newY >= 0 && newY < mat[0].length && mat[newX][newY] == -1) {
mat[newX][newY] = mat[x][y] + 1;
queue.offer(new int[] {newX, newY});
}
}
}
return mat;
}
}