You are given am x n2D grid initialized with these three possible values.
-1- A wall or an obstacle.
0- A gate.
INF- Infinity means an empty room. We use the value2^31- 1 = 2147483647to representINFas you may assume that the distance to a gate is less than2147483647.
Fill each empty room with the distance to itsnearestgate. If it is impossible to reach a gate, it should be filled withINF.
After running your function, the 2D grid should be:
3 -1 0 1
2 2 1 -1
1 -1 2 -1
0 -1 3 4
经典bfs。
public void wallsAndGates(int[][] rooms) {
if(rooms == null || rooms.length == 0 || rooms[0].length == 0) {
return;
}
int n = rooms.length;
int m = rooms[0].length;
Queue<Integer> queue = new LinkedList<>();
// put gates in queue
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (rooms[i][j] == 0) {
queue.offer(i * m + j);
}
}
}
int[] x = {0, 0, 1, -1};
int[] y = {1, -1, 0, 0};
while (!queue.isEmpty()) {
int cur = queue.poll();
int curi = cur / m;
int curj = cur % m;
for (int k = 0; k < 4; k++) {
int ni = curi + x[k];
int nj = curj + y[k];
if (inBound(ni, nj, rooms) && rooms[curi][curj] + 1 < rooms[ni][nj]) {
rooms[ni][nj] = rooms[curi][curj] + 1;
queue.offer(ni * m + nj);
}
}
}
}
private boolean inBound(int row, int col, int[][] rooms) {
if (row < 0 || col < 0 || row == rooms.length || col == rooms[0].length) {
return false;
}
return true;
}