并查集练习 —岛屿数量(解法一)

news/2024/12/29 3:32:08/

题目:
给定一个二维数组matrix(char[][]),里面的值不是1就是0,上、下、左、右相邻的1认为是一片岛。返回matrix中岛的数量。
本题共有2种解法,本篇先介绍最快的一种解法—递归。

分析:
递归的方式做这道题代码最简单,也是最好理解的。递归方式采用“”感染“”的策略。

  1. 如果matrix[i][j] = ‘1’,则先将自己的值改为2的ASCII码,并且从我出发去感染上、下、左、右四个方向。
  2. 如果上、下、左、右中,也有matrix[i][j] = ‘1’的,同1中处理方式ASCII改成2,继续向外感染。
  3. 在最外层的2层for循环中,如果碰到matrix[i][j] = ‘1’,则变量isLand + 1,经历一次感染过程就相当于发现了一座岛,感染多少不用管,因为不管感染多少每次感染都是一座岛屿。
  4. 为什么改成2,因为如果不改成2,等到绿色1感染的时候,绿色1的上下左右还会回来,GG,死循环了。

比方说下图:
在这里插入图片描述

遍历从最上角红色1开始感染,会将上下左右所有的1都改成2,如果此时修改完后,又变回了1,等到绿色1再次感染时,如果变回1,还会重新感染。

代码:

   public static int numIslands1(char[][] board) {int isLand = 0;for (int i = 0; i < board.length; i++) {for (int j = 0; j < board[0].length; j++) {if (board[i][j] == '1') {isLand++;infect(board,i,j);}}}return isLand;}public static void infect(char[][] board, int i, int j) {if (i < 0 || i == board.length || j < 0 || j == board.length || board[i][j] != '1') {return;}//如果是‘1’,改成2,并且上下左右去感染board[i][j] = 2;infect(board, i + 1, j);infect(board, i - 1, j);infect(board, i, j + 1);infect(board, i, j - 1);}

时间复杂度
如果二维数组行m,列n的话,整体复杂度就是 O ( m ∗ n ) O(m * n) O(mn)。虽然采用递归的方式,但是在主流程2个for循环中,所有数只循环了一遍,并且在感染过程里,需要修改成2的’1’,在下一次递归回来时,if条件不满足,直接renturn,‘0’的过程也是,所以所有数值走了一遍 O ( m ∗ n ) O(m * n) O(mn)


http://www.ppmy.cn/news/1009120.html

相关文章

第三章 关系数据库标准语言SQL

结构化查询语言&#xff08;Structed Query Language,SQL&#xff09;是关系数据库的标准语言&#xff0c;也是一个通用的&#xff0c;功能极强的关系数据库语言。 其功能不仅是查询&#xff0c;而且包括数据库模式创建&#xff0c;数据库数据的插入和修改&#xff0c;数据库安…

Modelsim打开后报unable to checkout a viewer license

找到Modelsim安装包中的MentorKG.exe文件和patch64_dll.bat文件&#xff0c;将这两个文件拷贝到Modelsim安装目录中的win64文件夹&#xff1a; 在win64文件夹中找到mgls64.dll&#xff0c;将它拷贝粘贴一份后修改名字为mgls.dll&#xff1a; 双击win64文件夹中的patch64_dll.ba…

SAP-FI-发票校验-总账科目录

1、业务场景 (1)如果某司机是按月结账,没有参照PO,而且每次记账的科目都不同,可能是办公费、原材料费,那么就需要直接记账到某一科目,输入基本数据的“CNY”,细节的“发票方”。 (2)如果项目期初上线,物料已收货,但是没有开票,不需要收货到系统,收到发票后,因…

【C#】.Net Framework框架下使用SQLike以及基本概念

2023年&#xff0c;第32周&#xff0c;第2篇文章。给自己一个目标&#xff0c;然后坚持总会有收货&#xff0c;不信你试试&#xff01; 在C#的.NET Framework框架下&#xff0c;有很多轻量级数据库选择&#xff0c;比如&#xff1a;SQLike就是其中一款&#xff0c;一起来了解SQ…

C++——new delete

本文主要介绍C中的new和delete&#xff0c;用于内存的申请和释放 1. 变量 示例 void variableFunc() //变量的使用 {int* ptr new int;*ptr 100;std::cout<<"ptr value is: "<<*ptr<<std::endl;delete ptr; //释放 }ptr 是一个指向 int 类…

一次redis缓存不均衡优化经验

背景 高并发接口&#xff0c;引入redis作为缓存之后&#xff0c;运行一段时间发现redis各个节点在高峰时段的访问量严重不均衡&#xff0c;有的节点访问量7000次/s&#xff0c;有的节点访问量500次/s 此种现象虽然暂时不影响系统使用&#xff0c;但是始终是个安全隐患&#x…

Leetcode周赛 | 2023-8-5

2023-8-5 题1体会我的代码 题2体会我的代码 题1 体会 一开始是觉得这道题是贪心的&#xff0c;选出现次数最多的元素&#xff0c;但是发现&#xff0c;当有多个元素出现次数均为最多时&#xff0c;似乎很难处理&#xff0c;就放弃了。转而问ChatGPT &#xff0c;结果让自己走上…

掌握Python的X篇_21_局部变量与全局变量

文章目录 1. python中的局部变量2. python中的全局变量3. 显式声明全局变量 1. python中的局部变量 函数内部定义的变量&#xff0c;是局部变量。局部变量只在当前函数中有效。 各个函数之间的局部变量是互相独立&#xff0c;互不影响的。 首先看一段代码&#xff1a; def f…