题目:岛屿数量
思路:深搜。
从头遍历矩阵,如果遇到一个1,解加1,然后深搜把这个1相连的1全部置为0。
注意:深搜要搜上下左右四个方向,不能只搜索右和下,因为有可能出现“ɔ”这种形状的岛屿,只搜索右方和下方不能覆盖这种情况。
代码:
import java.util.*;
public class Solution {
/**
* 判断岛屿数量
* @param grid char字符型二维数组
* @return int整型
*/
private int res = 0;
public int solve (char[][] grid) {
// write code here
int maxrow = grid.length;
int maxcol = grid[0].length;
boolean[][] visited = new boolean[maxrow][maxcol];
for (int i = 0; i < maxrow; i++) {
for (int j = 0; j < maxcol; j++) {
if (grid[i][j] == '1') {
res ++;
dfs(grid, i, j, maxrow, maxcol);
}
}
}
return res;
}
public void dfs(char[][] grid, int row, int col, int maxrow, int maxcol) {
if (grid[row][col] == '0') {
return;
}
grid[row][col] = '0';
if (row + 1 < maxrow) {
dfs(grid, row + 1, col, maxrow, maxcol);
}
if (row - 1 >= 0) {
dfs(grid, row - 1, col, maxrow, maxcol);
}
if (col + 1 < maxcol) {
dfs(grid, row, col + 1, maxrow, maxcol);
}
if (col - 1 >= 0) {
dfs(grid, row, col - 1, maxrow, maxcol);
}
}
}