leetcode—图 岛屿数量

news2024/10/4 23:58:46

岛屿数量

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

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

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

 方法

深度优先遍历

网格问题的基本概念

避免重复遍历:

使用标记

以岛屿问题为例,我们需要在所有值为 1 的陆地格子上做 DFS 遍历。每走过一个陆地格子,就把格子的值改为 2,这样当我们遇到 2 的时候,就知道这是遍历过的格子了。也就是说,每个格子可能取三个值:

  • 0 —— 海洋格子
  • 1 —— 陆地格子(未遍历过)
  • 2 —— 陆地格子(已遍历过)

代码一

统计网格中字符 '1' 出现的次数

class Solution {
    // 深度优先遍历 参考二叉树的DFS  图/网格  四叉
    public int numIslands(char[][] grid) {
        // 定义count 用于统计岛屿的数量
        int count = 0;
        // 遍历网格
        for(int r = 0; r < grid.length; r++){
            for(int c = 0 ; c < grid[0].length; c++){
                // 若当前网格的值为“1”,则为陆地,遍历其的上下左右
                if(grid[r][c] == '1'){
                    // 调用递归函数
                    dfsHelp(grid, r, c);
                    // 统计岛屿数量 由多个陆地组成
                    count ++;
                }
            }
        }
        // 返回结果
        return count;
        
    }

    // 递归函数
    public void dfsHelp(char[][] grid, int row, int column){
        // 递归出口 防止网格越界
        if(row < 0 || column < 0 || (row >= 0 && row < grid.length) || (column >= 0 && column < grid[0].length)){
            return;
        }
        // 若网格为海洋 即值为"0"时 或者值为"2"时,也退出
        if(grid[row][column] == '0'|| grid[row][column] == '2'){
            return ;
        }
        // 将遍历过的陆地1 标记为2
        grid[row][column] = '2';

        // 递归遍历
        dfsHelp(grid, row - 1, column);   // 上
        dfsHelp(grid, row + 1, column);   // 下
        dfsHelp(grid, row, column -1);    // 左
        dfsHelp(grid, row, column +1);    // 右

    }
}

代码二

修改之后的代码

class Solution {
    // 深度优先遍历 参考二叉树的DFS  图/网格  四叉
    public int numIslands(char[][] grid) {
        // 首先对网格进行判空
        if(grid == null || grid.length == 0){
            return 0;
        }
        // 定义count 用于统计岛屿的数量
        int count = 0;
        // 遍历网格
        for(int r = 0; r < grid.length; r++){
            for(int c = 0 ; c < grid[0].length; c++){
                // 若当前网格的值为“1”,则为陆地,遍历其的上下左右
                if(grid[r][c] == '1'){
                    // 调用递归函数
                    dfsHelp(grid, r, c);
                    // 统计岛屿数量 由多个陆地组成
                    count ++;
                }
            }
        }
        // 返回结果
        return count;
        
    }
 
    // 递归函数
    public void dfsHelp(char[][] grid, int row, int column){
        // 递归出口 防止网格越界
        if(row < 0 || column < 0 || row >= grid.length || column >= grid[0].length){
            return;
        }
        // 若网格为海洋 即值为"0"时 或者值为"2"时,即值不等于1时 也退出
        if(grid[row][column] != '1'){
            return ;
        }
        // 将遍历过的陆地1 标记为2
        grid[row][column] = '2';
 
        // 递归遍历
        dfsHelp(grid, row - 1, column);   // 上
        dfsHelp(grid, row + 1, column);   // 下
        dfsHelp(grid, row, column -1);    // 左
        dfsHelp(grid, row, column +1);    // 右
 
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1404959.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言 小明喝饮料

题目&#xff1a;喝汽水&#xff0c;1瓶汽水1元&#xff0c;2个空瓶可以换汽水&#xff0c;给n元&#xff0c;可以喝多少汽水//理论问题&#xff0c;请勿模仿-^- #include <stdio.h> int main() {int n,ret,i;scanf("%d", &n);ret n;while (n>1){ret …

JavaEE:多线程(2):线程状态,线程安全

目录 线程状态 线程安全 线程不安全 加锁 互斥性 可重入 死锁 死锁的解决方法 Java标准库中线程安全类 内存可见性引起的线程安全问题 等待和通知机制 线程饿死 wait notify 线程状态 就绪&#xff1a;线程随时可以去CPU上执行&#xff0c;也包含在CPU上执行的…

csdn发布文章审核一直未通过解决办法

搞了很久的confluence&#xff0c;踩了很多坑终于弄好了&#xff0c;却一直显示审核不通过&#xff0c;给笔记一顿狂改还是不通过&#xff0c;一直说是版权问题就很让人起疑&#xff0c;最后问了客服才知道&#xff0c;现在开始查版权问题&#xff0c;所以我给confluence笔记中…

【开发日记】换掉Nginx,使用HAProxy作为反向代理服务器

HAProxy&#xff0c;全称为 "High Availability Proxy"&#xff0c;是一款开源的、高性能的负载均衡器和代理服务器。主要用于改善应用程序的可用性、可靠性和性能。 与大众熟知的Nginx相比各有优缺点&#xff0c;如果你需要的是一个Web服务器&#xff0c;还是首选N…

GitHub README-Template.md - README.md 模板

GitHub README-Template.md - README.md 模板 1. README-Template.md 预览模式2. README-Template.md 编辑模式References A template to make good README.md. https://gist.github.com/PurpleBooth/109311bb0361f32d87a2 1. README-Template.md 预览模式 2. README-Templat…

AI对比:ChatGPT和文心一言的区别和差异

目录 一、ChatGPT和文心一言大模型的对比分析 1.1 二者训练的数据情况分析 1.2 训练大模型数据规模和参数对比 1.3 二者3.5版本大模型对比总结 二、ChatGPT和文心一言功能对比分析 2.1 二者产品提供的功能情况分析 2.2 测试一下各种功能的特性 2.2.1 文本创作能力 2.2…

websocket服务端本地部署

文章目录 1. Java 服务端demo环境2. 在pom文件引入第三包封装的netty框架maven坐标3. 创建服务端,以接口模式调用,方便外部调用4. 启动服务,出现以下信息表示启动成功,暴露端口默认99995. 创建隧道映射内网端口6. 查看状态->在线隧道,复制所创建隧道的公网地址加端口号7. 以…

Samtec微波、毫米波连接器系统实现卓越性能

【摘要/前言】 在IMS 2023展会上&#xff0c;Samtec 的展台展示了各种尖端产品和技术。其中之一是各种微波、毫米波连接器系统&#xff0c;这些系统性能卓越&#xff0c;令人印象深刻。 Samtec射频设计与仿真工程经理Michael Griesi向我们介绍了演示过程和结果。 【Demo演示】…

Qt5.12.0 与 VS2017 在 .pro文件转.vcxproj文件

一、参考资料 stackoverflow qt - How to generate .sln/.vcproj using qmake - Stack Overflowhttps://stackoverflow.com/questions/2339832/how-to-generate-sln-vcproj-using-qmake?answertabtrending#tab-topqt - 如何使用 qmake 生成 .sln/.vcproj - IT工具网 (coder.wo…

综合小型气象观测站

TH-QC12随着科技的发展&#xff0c;气象观测站已经变得越来越普遍。无论是大规模的国家级气象站&#xff0c;还是小型的气象观测站&#xff0c;它们都为我们的生活和生产提供了重要的气象数据。 综合小型气象观测站&#xff0c;顾名思义&#xff0c;它集成了多种气象观测设备&a…

如何搭建一个短视频社区?这篇文章告诉你

短视频社区是随着手机拍摄和社交媒体的普及而兴起的一种社区形式。 短视频社区通过提供用户生成的短视频内容&#xff0c;并与其他用户互动和分享&#xff0c;为用户提供了一个展示自己才华和创造力的平台。当前已经成为全球范围内的热门社交媒体形式&#xff0c;市场情况非常…

Apache Zeppelin结合Apache Airflow使用1

Apache Zeppelin结合Apache Airflow使用1 文章目录 Apache Zeppelin结合Apache Airflow使用1前言一、安装Airflow二、使用步骤1.目标2.编写DAG2.加载、执行DAG 总结 前言 之前学了Zeppelin的使用&#xff0c;今天开始结合Airflow串任务。 Apache Airflow和Apache Zeppelin是两…

DAY07_SpringBoot—用法整合MyBatis

目录 1 SpringBoot 用法1.1 环境切换1.1.1 业务需求1.1.2 多环境编辑 1.2 热部署1.2.1 需求说明1.2.2 引入jar包1.2.3 配置IDEA环境 2 SpringBoot整合Mybatis2.1 导入数据库2.2 创建SpringBoot项目2.2.1 创建项目2.2.2 生成POM.xml文件如下2.2.3 Mavenjar包作用范围2.2.4 数据源…

面试经验分享 | 工控安全研究员

本文由掌控安全学院 - 徐浩洋 投稿 笔试 进程注入有几种简单描述一下? Windows异常分发流程。 Windows下反调试和反反调试的手段。 使用分页机制下虚拟地址怎么翻译为物理地址。 符号延时加载(DeferredSymbolLoading)的原理? 漏洞触发流程是怎么样的,怎么定位触发点如何进行…

服务器数据恢复—服务器进水导致阵列中磁盘同时掉线的数据恢复案例

服务器数据恢复环境&#xff1a; 数台服务器数台存储阵列柜&#xff0c;共上百块硬盘&#xff0c;划分了数十组lun。 服务器故障&检测&#xff1a; 外部因素导致服务器进水&#xff0c;进水服务器中一组阵列内的所有硬盘同时掉线。 北亚数据恢复工程师到达现场后发现机房内…

OpenMP和MPI环境配置

目录 OpenMP和MPI环境配置OpenMP环境配置MPI环境配置&#xff08;Windows&#xff09;MPI环境配置&#xff08;Ubuntu&#xff09; 参考资料 OpenMP和MPI环境配置 OpenMP环境配置 首先创建项目&#xff0c;选择C 控制台应用。 选择项目&#xff0c;属性。 在C/C —— 语言中&…

老师家访的目的是什么

家访&#xff0c;对于老师来说&#xff0c;是工作中必不可少的一部分。有人会问&#xff0c;老师家访的目的是什么呢&#xff1f;是为了了解学生的家庭情况&#xff0c;还是为了和家长建立良好的沟通关系&#xff1f;其实&#xff0c;老师家访的目的远不止于此。 老师家访是为…

【MySQL】计算日期是当前月份的第几周

力扣题 1、题目地址 2993. 发生在周五的交易 I 2、模拟表 表&#xff1a;Purchases Column NameTypeuser_idintpurchase_datedateamount_spendint (user_id, purchase_date, amount_spend) 是该表的主键(具有唯一值的列)。purchase_date 的范围从 2023 年 11 月 1 日到 2…

对称图做法,全程动图演示

最终效果&#xff1a; 实现步骤&#xff1a; 其他图形画法&#xff1a; 点线对比图做法&#xff0c;全程动图演示 气泡图做法&#xff0c;全程动图演示 重叠柱状图做法&#xff0c;全程动图演示 瀑布图做法&#xff0c;全程动图演示 对称图做法&#xff0c;全程动图演示

轻松上手:通过阿里云PAI QuickStart微调部署Qwen-72B-Chat模型

作者&#xff1a;熊兮、求伯、一耘 引言 通义千问-72B&#xff08;Qwen-72B&#xff09;是阿里云研发的通义千问大模型系列的720亿参数规模模型。Qwen-72B的预训练数据类型多样、覆盖广泛&#xff0c;包括大量网络文本、专业书籍、代码等。Qwen-72B-Chat是在Qwen-72B的基础上…