Number of Islands
Last updated
Last updated
class Solution {
int[][] dirs = new int[][]{{1, 0}, {0, 1}, {-1, 0}, {0, -1}};
private void dfs(char[][] grid, int i, int j) {
int m = grid.length, n = m == 0 ? 0 : grid[0].length;
if (i >= 0 && i < m && j >= 0 && j < n && grid[i][j] == '1') {
grid[i][j] = '0';
for (int[] dir : dirs) {
dfs(grid, i + dir[0], j + dir[1]);
}
}
}
public int numIslands(char[][] grid) {
int m = grid.length, n = m == 0 ? 0 : grid[0].length;
int count = 0;
for (int i = 0; i < m; i++) {
for (int j = 0; j < n; j++) {
if (grid[i][j] == '1') {
dfs(grid, i, j);
count++;
}
}
}
return count;
}
}