图论-岛屿数量

岛屿数量

java 复制代码
给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量。

岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。

此外,你可以假设该网格的四条边均被水包围

输入 :二维字符数组
输出 :整型变量
思路:只要有一个"1",则找到与他相邻的所有的"1",将其都置为"0",有点像递归的思路,然后直到遇到一个不为"1",则岛屿数加一

java 复制代码
class Solution {
    public int numIslands(char[][] grid) {
        int num = 0;
        //遍历数组
        for(int i = 0; i < grid.length; i++){
            for(int j = 0; j < grid[0].length; j++){
                if(grid[i][j] == '1'){
                    num++;
                    dfs(grid,i,j);
                }
            }
        }
        return num;
    }
    void dfs(char[][] grid, int i, int j){
        //避免空指针异常
        if(i < 0 || j < 0 || i >= grid.length || j >= grid[0].length || grid[i][j] == '0'){
            return;
        }
        grid[i][j] = '0';
        dfs(grid,i - 1, j);
        dfs(grid,i + 1, j);
        dfs(grid,i, j + 1);
        dfs(grid,i, j - 1);
    }
}
相关推荐
周航宇JoeZhou1 小时前
JP3-3-MyClub后台后端(二)
java·mysql·vue·ssm·springboot·项目·myclub
DIY机器人工房1 小时前
一个可以检测本机的字节顺序,并对任意数据进行字节顺序的反转操作的代码。
嵌入式硬件·算法·嵌入式·diy机器人工房
羊锦磊2 小时前
[ java 网络 ] TPC与UDP协议
java·网络·网络协议
找不到、了2 小时前
Java设计模式之<建造者模式>
java·设计模式·建造者模式
杰克尼3 小时前
11. 盛最多水的容器
算法·leetcode·职场和发展
Code blocks3 小时前
关于“LoggerFactory is not a Logback LoggerContext but Logback is on ......“的解决方案
java·spring boot·后端
程序员Xu5 小时前
【OD机试题解法笔记】查找接口成功率最优时间段
笔记·算法
云泽8085 小时前
数据结构前篇 - 深入解析数据结构之复杂度
c语言·开发语言·数据结构
逝雪Yuki5 小时前
数据结构与算法——字典(前缀)树的实现
数据结构·c++·字典树·前缀树·左程云
技术思考者6 小时前
Leetcode - 反转字符串
数据结构·算法·leetcode