Queue<int[]> queue = new ArrayDeque<>(); int m = grid.length, n = grid[0].length; // 先把所有的陆地都入队。 for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { if (grid[i][j] == 1) { queue.offer(newint[] {i, j}); } } }
// 从各个陆地开始,一圈一圈的遍历海洋,最后遍历到的海洋就是离陆地最远的海洋。 boolean hasOcean = false; int[] point = null; while (!queue.isEmpty()) { point = queue.poll(); int x = point[0], y = point[1]; // 取出队列的元素,将其四周的海洋入队。 for (int i = 0; i < 4; i++) { int newX = x + dx[i]; int newY = y + dy[i]; if (newX < 0 || newX >= m || newY < 0 || newY >= n || grid[newX][newY] != 0) { continue; } grid[newX][newY] = grid[x][y] + 1; // 这里我直接修改了原数组,因此就不需要额外的数组来标志是否访问 hasOcean = true; queue.offer(newint[] {newX, newY}); } }