牛客在线编程101-57 岛屿数量

描述 给一个01矩阵,1代表是陆地,0代表海洋, 如果两个1相邻,那么这两个1属于同一个岛。我们只考虑上下左右为相邻。 岛屿: 相邻陆地可以组成一个岛屿(相邻:上下左右) 判断岛屿个数。

import java.util.*;


public class Solution {
          
   
    /**
     * 判断岛屿数量
     * @param grid char字符型二维数组
     * @return int整型
     */
    public int solve (char[][] grid) {
          
   
        // write code here
        int m = grid.length;
        if (m == 0) {
          
   
            return 0;
        }
        int n = grid[0].length;

        int res = 0;
        //将岛屿及其周围全部置0
        for (int i = 0; i < m; i++) {
          
   
            for (int j = 0; j < n; j++) {
          
   
                if (grid[i][j] == 1) {
          
   
                    res++;
                    //用dfs搜索周围所有的1
                    dfs(grid, i, j, m, n);
                }
            }
        }

        return res;
    }

    public void dfs(char[][] grid, int i, int j, int m, int n) {
          
   
        grid[i][j] = 0;
        //上
        if (i - 1 >= 0 && grid[i - 1][j] == 1) {
          
   
            dfs(grid, i - 1, j, m, n);
        }
        //下
        if (i + 1 < m && grid[i + 1][j] == 1) {
          
   
            dfs(grid, i + 1, j, m, n);
        }
        //右
        if (j + 1 < n && grid[i][j + 1] == 1) {
          
   
            dfs(grid, i, j + 1, m, n);
        }
        //左
        if (j - 1 >= 0 && grid[i][j - 1] == 1) {
          
   
            dfs(grid, i, j - 1, m, n);
        }
    }
}
经验分享 程序员 微信小程序 职场和发展