LeetCode:200岛屿数量

方法一:

java 复制代码
class Solution {
    public int numIslands(char[][] grid) {
        //空网格判断
        if(grid == null || grid.length == 0){
            return 0;
        }

        int count = 0;
        int row = grid.length;
        int cols = grid[0].length;
        //循环遍历每一个网格
        for(int r = 0; r < row; r++){
            for(int c = 0; c < cols; c++){
                if(grid[r][c] == '1'){
                    count++;
                    //将该网格以及上下左右的网格置为0
                    sinkIsland(grid, r, c);
                }
            }
        }
        return count;
    }
    //处理'1'以及周边置为'0'
    private void sinkIsland(char[][] grid, int r, int c){
        if(r < 0 || r >= grid.length || c < 0 || c >= grid[0].length || grid[r][c] == '0'){
            return;
        }

        grid[r][c] = '0';

        sinkIsland(grid, r - 1, c);
        sinkIsland(grid, r, c - 1);
        sinkIsland(grid, r + 1,c);
        sinkIsland(grid, r, c +1);
    }
}

这里注意图里面给的都是字符,所以在比较的时候应该使用'0'而不是直接0;另外"="是赋值运算符,"=="是比较运算符,返回的是true和false。

方法二:

java 复制代码
class Solution {
    public int numIslands(char[][] grid) {
        //空网格判断
        if(grid == null || grid.length == 0){
            return 0;
        }

        int count = 0;
        int row = grid.length;
        int cols = grid[0].length;

        boolean[][] visited = new boolean[row][cols];

        //循环遍历每一个网格
        for(int r = 0; r < row; r++){
            for(int c = 0; c < cols; c++){
                if(grid[r][c] == '1' && !visited[r][c]){
                    count++;
                    
                    dfs(grid, r, c,visited);
                }
            }
        }
        return count;
    }
    //在新建的二维数组visited上进行操作
    private void dfs(char[][] grid, int r, int c, boolean[][] visited){
        if(r < 0 || r >= grid.length || c < 0 || c >= grid[0].length || grid[r][c] == '0' || visited[r][c]){
            return;
        }

        visited[r][c] = true;

        dfs(grid, r - 1, c, visited);
        dfs(grid, r, c - 1, visited);
        dfs(grid, r + 1, c, visited);
        dfs(grid, r, c +1, visited);
    }
}

方法一的思路是在原数组上做修改,但是实际业务中可能不允许这样做,所以引出了第二种方法,新建了一个二维数组,与方法一直接在原来数组上进行置0操作不同的地方在于,方法二在新建的boolean数组中进行将默认的false置为true的操作。

方法二思路:

循环遍历元素,只有满足该格为1且boolean数组为true才count++,然后在boolean数组中将身边的元素置为true,这样下次遍历的这里的时候就不会执行count++操作了;需要注意的是在双层循环的遍历条件中!visitedrc这个条件的使用,因为初始化数组是false;另外后续将boolean数组中的元素置为ture从而可以实现在后续的循环中当作fasle进行跳过的步骤。

相关推荐
JAVA面经实录91714 小时前
Java 数据结构与算法 (终极完整学习文档)
java·数据结构·算法
程序员三藏15 小时前
Web自动化测试详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
开源Z15 小时前
LeetCode 42 · 接雨水:从暴力到双指针的三步优化
算法·leetcode
旖-旎15 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
syagain_zsx16 小时前
STL 之 vector 讲练结合
c++·算法
MartinYeung517 小时前
[论文学习]DP2Unlearning:高效且具保证的大型语言模型遗忘框架(基于差分隐私的 LLM Unlearning 方法)
学习·算法·语言模型
Tian_Hang18 小时前
C++原型模式(Protype)
开发语言·c++·算法
bIo7lyA8v18 小时前
算法复杂度的渐进分析与实际运行时间的差异的技术8
算法
yuan1999718 小时前
欧拉梁静力与屈曲计算的 MATLAB 实现(有限差分法 + 解析解)
开发语言·算法·matlab