leedcode 1254. 统计封闭岛屿的数目

2023-11-07

题目:

二维矩阵 grid0 (土地)和 1 (水)组成。岛是由最大的4个方向连通的 0 组成的群,封闭岛是一个 完全 由1包围(左、上、右、下)的岛。

思路:封闭岛屿是由1完全包围的岛,也就是说,该岛屿不能在二维矩阵的边界处,这种情况排出后,统计剩余的封闭岛屿即可

广度优先遍历

代码如下:

class Solution {
    int[][] a = {{1,0},{-1,0},{0,1},{0,-1}};

    public int closedIsland(int[][] grid) {
        int nx = grid.length;
        int ny = grid[0].length;
        int num = 0;//用于记录封闭岛屿的数量

        for (int r = 0; r < nx ; r++) {

            for (int c = 0; c < ny; c++) {//依次对每个位置进行遍历

                if(grid[r][c] == 0) {

                    grid[r][c] = 1;
                    Queue<int[]> que = new ArrayDeque<int[]>();
                    que.add(new int[] {r,c});
                    boolean fal = true;//用于判断是否为封闭岛屿

                    while(!que.isEmpty()) {//将该岛屿扩展

                        int[] ret =que.poll();
                        int x = ret[0], y = ret[1];

                        if(x == 0 || y == 0 || x == nx - 1 || y == ny - 1) {
                          //如果该岛屿存在边界处,则不是封闭岛屿
                            fal = false;
                        }

                        for (int k = 0; k < 4; k++) {//对该点上下左右进行遍历

                            int dx = x + a[k][0], dy = y + a[k][1];

                            if (dx >= 0 && dx < nx && dy >= 0 && dy < ny && grid[dx][dy] == 0) {//判断是否进行扩展
                                que.add(new int[]{dx,dy});
                                grid[dx][dy] = 1;
                            }
                        }
                    }

                    if (fal) {//如果为封闭岛屿则num++
                        num++;
                    }
                }
            }
        }
        return num;
    }
}

深度优先遍历

代码如下:

class Solution {
    boolean fal;//用于判断是否为封闭岛屿
    int dx;
    int dy;

    public int closedIsland (int[][] grid) {
        dx = grid.length;
        dy = grid[0].length;
        int num = 0;

        for(int r = 0;r < dx;r++){

            for(int c = 0;c < dy;c++){

                if(grid[r][c] == 0){//统计个数
                    fal = true;
                    dfs(grid,r,c);

                    if(fal) {
                        num++;
                    }
                }
            }
        }
        return num;
    }

    public void dfs (int[][] grid,int row,int col) {

        if(row < 0 || row >= dx || col < 0 || col >= dy || grid[row][col] == 1) {
            return;
        }

        if (row == 0 || row == dx - 1 || col == 0 || col == dy - 1) {//判断岛屿处于边界情况
            fal = false;
        }

        grid[row][col] = 1;

        dfs(grid,row+1,col);

        dfs(grid,row-1,col);

        dfs(grid,row,col+1);

        dfs(grid,row,col-1);
    }
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

leedcode 1254. 统计封闭岛屿的数目 的相关文章

随机推荐

  • 机械革命 键盘灯 linux,机械革命x6Ti安装ubuntu(100%成功)

    这个教程是本人亲自试验成功的 方案为ssd不变 ubuntu装在机械硬盘 步骤 1 在电脑的机械硬盘中压缩出一个大小为200G的空间 无论哪个盘 你按自己的需求压缩大小 2 在官网下载系统镜像 解压到U盘中 由于这款电脑的主板新 所以直接解
  • SpringBoot-Thymeleaf-MySQL-SpringMVC实现网页端的数据库信息的增删改查(JavaEE巨详细版)

    Hello 欢迎来到我的博客 既然选择了远方 便只顾风雨兼程 源码已上传资源 0积分获取 觉得有用的点个赞嘛 源码点击这里 上一篇 博客只实现了数据库信息的网页端展示 本篇博客我们来更详细的写一下学生信息管理系统的网页端跳转版增删改查 ht
  • 计算机网络 day8 动态路由 - NAT - SNAT实验 - VMware的网卡的3种模式

    目录 动态路由 IGP 和 EGP 参考网课 4 6 1 路由选择协议概述 哔哩哔哩 bilibili 编辑 IGP Interior Gateway Protocol 内部网关协议 EGP Interior Gateway Protoco
  • 子类实例化对象的全过程

    子类实例化对象的全过程 我们只造了一个对象dog 但是dog的构造器直接或间接的调用了直接父类或间接父类的构造器来加载他们的属性和方法 子类对象实例化全过程图示 从结果上来看 继承性 子类继承父类以后就获取了父类中声明的属性和方法 创建子类
  • 信息隐藏——DCT隐写

    DCT隐写 实验目的 了解DCT的系数隐写 实验内容 Jepg 压缩算法的回顾 用MATLAB实现图像DCT相关操作 完成基于图像DCT的信息隐藏实验 两点法的嵌入和提取 三点法的嵌入和提取 1 Jpeg压缩算法 一 色彩空间转换 RGB空
  • 学习日记--8.5--linux初装

    1 用xmms播放mp3 首先linux自带的xmms缺少一个插件 可以先下载并且安装 xmms mpg123 1 2 7 13 i386 rpm 但是如此之后可能还不可以使用 播放一秒就死住 这时候 在xmms 运行后之上点击 右键 gt
  • FreeAnchor:令anchor自由匹配标签的策略

    前言 本文将要介绍一种为训练样本分配标签的策略 这种策略称作 FreeAnchor 注意不是 anchor free 哦 FreeAnchor 是用于 anchor based 体系下的策略 那么它到底free在哪里呢 anchor还能玩起
  • TOP命令参数详解

    TOP命令详解 一 top命令介绍 相信每个运维人员都遇到过的事情就是服务器的负载突然飙升 碰到这种情况 大家第一反应一定是登到服务器上 先敲一个top命令看看load average吧 在Linux操作系统中 top是使用最频繁 也是信息
  • vue改变数组的值,样式控制没变化

    目录 问题背景 解决方案 第一种 使用this set target index value 第二种 this forceUpdate 参考 问题背景 我用0 1 控制隐藏还是显示 因为有多个所以用的数组 如下代码 省略 data retu
  • MATLAB怎么使用table格式读取csv文件并画图

    MATLAB中新增了一个table类型 可以很方便的读取文件中的数据 在使用这个格式的时候会默认把读取文件的第一行设置为标题 访问的时候需要通过索引值进行访问 具体怎么操作通过一个MATLAB例子进行说明 MATLAB代码 T readta
  • c 语言怎么释放链表节点,C:如何释放链表中的节点?

    我如何释放在另一个函数中分配的节点 struct node int data struct node next struct node buildList struct node head NULL struct node second N
  • 揭开数学智慧的神秘面纱:MathGPTPro使用指南带你领略数学的魅力!

    请查收一份MathGPTPro的使用指南 欢迎大家进入我们的MathGPTPro群 我们产品的链接在这 https mathgptpro com 欢迎大家踊跃提问 大家可以文字或者图片 也支持手写图片 输入问题 遇到回答中不解的问题 公式
  • MYSQL学习笔记(二)——数据库和数据表操作

    MYSQL数据库学习笔记 二 目录 MYSQL数据库学习笔记 二 一 MYSQL数据库操作 一 创建数据库 二 指定当前数据库 三 修改数据库 四 删除数据库 二 数据表操作 一 创建数据表 二 复制现成的表 三 修改数据表 1 add实例
  • 关于电脑丢失msvcr120.dll的几个修复方法

    MSVCR120 dll它是Windows系统运行某些程序所需的文件之一 如果你在运行某个程序时遇到了MSVCR120 dll丢失的错误 那么你不能简单地忽略它 因为这可能会导致程序无法正常运行 在本篇文章中 我们将为大家介绍一些解决MSV
  • MySQL高效编程学习笔记(五)--表的维护和改造

    修改表的列结构 若表中有数据最好先备份 注意转换前后的字符长度 以及是否可以互相转换等问题 改变列数据类型 ALTER TABLE visitor MODIFY nam VARCHAR 30 Eg alter table goods mod
  • 用Node.js实现一个HTTP服务器程序(文件服务器)

    http Node js开发的目的就是为了用JavaScript编写Web服务器程序 因为JavaScript实际上已经统治了浏览器端的脚本 其优势就是有世界上数量最多的前端开发人员 如果已经掌握了JavaScript前端开发 再学习一下如
  • 基于java的Mock利器-Mockito

    1 认识Mockito Mockito是java单元测试中使用率最高的Mock框架之一 特点 简明的语法和完整的文档 Mockito支持永Maven和Gradle来进行依赖引入和管理 2 Mockito Maven引入
  • 记一次Redis配置database不生效的问题

    1 先贴代码 乍一看 这个配置没问题 redis也在spring下 springboot 的 Configuration 也会默认加载redis的配置 但是一开始怎么调试都不能默认数据库为1的情况 后来我在Redis配置中发现了另一个好东东
  • Linux下重要文件不小心被删除?别着急,看这里!

    针对日常维护操作 难免会出现文件误删除的操作 大家熟知linux文件系统不同win有回收站 删除后的文件可以到垃圾箱寻回 要知道linux文件修复比较费劲 网络上面的文档也是五花八门 所以本次研究一种比较靠谱的文件和目录恢复方法 也给维护人
  • leedcode 1254. 统计封闭岛屿的数目

    题目 二维矩阵 grid 由 0 土地 和 1 水 组成 岛是由最大的4个方向连通的 0 组成的群 封闭岛是一个 完全 由1包围 左 上 右 下 的岛 思路 封闭岛屿是由1完全包围的岛 也就是说 该岛屿不能在二维矩阵的边界处 这种情况排出后