每日一练:LeeCode-200、岛屿数量【DFS递归+BFS队列】

news/2025/2/23 6:05:09/

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

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

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

示例 1:

输入:grid = [["1","1","1","1","0"],["1","1","0","1","0"],["1","1","0","0","0"],["0","0","0","0","0"]
]
输出:1

示例 2:

输入:grid = [["1","1","0","0","0"],["1","1","0","0","0"],["0","0","1","0","0"],["0","0","0","1","1"]
]
输出:3

提示:

  • m == grid.length
  • n == grid[i].length
  • 1 <= m, n <= 300
  • grid[i][j] 的值为 '0''1'

方法1:DFS(系统栈=递归)

这题让求的是岛屿的数量,二维数组中值是1的都是岛屿,如果多个1是连着的,那么他们只能算一个岛屿

思路:

​ 最简单的一种方式就是遍历数组中的每一个值,如果是1就说明是岛屿,然后把它置为0或者其他的字符都可以,只要不是1就行,然后再遍历他的上下左右4个位置。如果是1,说明这两个岛屿是连着的,只能算是一个岛屿,我们还要把它置为0,然后再以它为中心遍历他的上下左右4个位置……。如果是0,就说明不是岛屿,就不在往他的上下左右4个位置遍历了。这里就以示例1为例来看一下

在这里插入图片描述

public int numIslands(char[][] grid) {//边界条件判断if (grid == null || grid.length == 0)return 0;//统计岛屿的个数int count = 0;//两个for循环遍历每一个格子for (int i = 0; i < grid.length; i++)for (int j = 0; j < grid[0].length; j++) {//只有当前格子是1才开始计算if (grid[i][j] == '1') {//如果当前格子是1,岛屿的数量加1count++;//然后通过dfs把当前格子的上下左右4//个位置为1的都要置为0,因为他们是连着//一起的算一个岛屿,dfs(grid, i, j);}}//最后返回岛屿的数量return count;
}//这个方法会把当前格子以及他邻近的为1的格子都会置为0
public void dfs(char[][] grid, int i, int j) {//边界条件判断,不能越界if (i < 0 || i >= grid.length || j < 0 || j >= grid[0].length || grid[i][j] == '0')return;//把当前格子置为0,然后再从他的上下左右4个方向继续遍历grid[i][j] = '0';dfs(grid, i - 1, j);//上dfs(grid, i + 1, j);//下dfs(grid, i, j + 1);//左dfs(grid, i, j - 1);//右
}

方法2:BFS(队列)

DFS就是沿着一条路径一直走下去,当遇到终止条件的时候才会返回,而BFS就是先把当前位置附近
的访问一遍,就像下面这样先访问圈内的,然后再把圈放大继续访问
,就像下面这样

在这里插入图片描述
这题使用BFS和DFS都能解决,如果遇到位置为1的格子,只要能把他们挨着的为1的全部置为0,然后挨着的挨着的为1的位置也置为0,然后…一直这样循环下去,看下代码

public int numIslands(char[][] grid) {//边界条件判断if (grid == null || grid.length == 0)return 0;//统计岛屿的个数int count = 0;//两个for循环遍历每一个格子for (int i = 0; i < grid.length; i++)for (int j = 0; j < grid[0].length; j++) {//只有当前格子是1才开始计算if (grid[i][j] == '1') {//如果当前格子是1,岛屿的数量加1count++;//然后通过bfs把当前格子的上下左右4//个位置为1的都要置为0,因为他们是连着//一起的算一个岛屿,bfs(grid, i, j);}}return count;
}private void bfs(char[][] grid, int x, int y) {//把当前格子先置为0grid[x][y] = '0';int n = grid.length;int m = grid[0].length;//使用队列,存储的是格子坐标转化的值Queue<Integer> queue = new LinkedList<>();//我们知道平面坐标是两位数字,但队列中存储的是一位数字,//所以这里是把两位数字转化为一位数字int code = x * m + y;//坐标转化的值存放到队列中queue.add(code);while (!queue.isEmpty()) {//出队code = queue.poll();//在反转成坐标值(i,j)int i = code / m;int j = code % m;if (i > 0 && grid[i - 1][j] == '1') {//上//如果上边格子为1,把它置为0,然后加入到队列中//下面同理grid[i - 1][j] = '0';queue.add((i - 1) * m + j);}if (i < n - 1 && grid[i + 1][j] == '1') {//下grid[i + 1][j] = '0';queue.add((i + 1) * m + j);}if (j > 0 && grid[i][j - 1] == '1') { //左grid[i][j - 1] = '0';queue.add(i * m + j - 1);}if (j < m - 1 && grid[i][j + 1] == '1') {//右grid[i][j + 1] = '0';queue.add(i * m + j + 1);}}
}

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

相关文章

WPF---1.入门学习

学习来源 布局 wpf布局原则 一个窗口中只能包含一个元素 不应显示设置元素尺寸 不应使用坐标设置元素的位置 可以嵌套布局容器 StackPanel-->表单条件查找布局 DataGrid wpf布局容器 StackPanel: 水平或垂直排列元素&#xff0c;Orientation属性分别: Horizontal / Vertic…

Spring Cloud Alibaba Sentinel 使用详解

一、Sentinel 介绍 随着微服务的流行&#xff0c;服务和服务之间的稳定性变得越来越重要。 Sentinel 以流量为切入点&#xff0c;从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。 Sentinel 具有以下特征: 丰富的应用场景&#xff1a; Sentinel 承接了阿里巴…

基于CNN-RNN的动态手势识别系统实现与解析

一、环境配置 为了成功实现基于CNN-RNN的动态手势识别系统&#xff0c;你需要确保你的开发环境已经安装了以下必要的库和工具&#xff1a; Python&#xff1a;推荐使用Python 3.x版本&#xff0c;作为主要的编程语言。TensorFlow&#xff1a;深度学习框架&#xff0c;用于构建…

BC98 序列中删除指定数字

题目 描述 有一个整数序列&#xff08;可能有重复的整数&#xff09;&#xff0c;现删除指定的某一个整数&#xff0c;输出删除指定数字之后的序列&#xff0c;序列中未被删除数字的前后位置没有发生改变。 数据范围&#xff1a;序列长度和序列中的值都满足 1≤&#xfffd;≤…

iMazing2024功能强大的iPhone和iPad管理工具

iMazing是一款功能强大的iPhone和iPad管理工具&#xff0c;确实可以作为iTunes的替代品进行数据备份。以下是一些关于iMazing的主要特点和功能&#xff1a; 设备备份&#xff1a;iMazing可以备份iOS设备上的所有数据&#xff0c;包括照片、视频、音乐、应用程序等。与iTunes相比…

java数据结构与算法刷题-----LeetCode605. 种花问题

java数据结构与算法刷题目录&#xff08;剑指Offer、LeetCode、ACM&#xff09;-----主目录-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/123063846 文章目录 贪心思想 贪心思想 解题思路&#xff1a;时间复杂度O( n n n)&a…

为何ChatGPT日耗电超50万度?

看新闻说&#xff0c;ChatGPT每天的耗电量是50万度&#xff0c;国内每个家庭日均的耗电量不到10度&#xff0c;ChatGPT耗电相当于国内5万个家庭用量。 网上流传&#xff0c;英伟达创始人黄仁勋说&#xff1a;“AI的尽头是光伏和储能”&#xff0c;大佬的眼光就是毒辣&#xff…

QT环境搭建

学习QT 一、QT环境搭建二、QT的SDK下载三、认识QT SDK 中自带的一些程序 一、QT环境搭建 QT开发环境&#xff0c;需要安装三个部分。 c编译器&#xff08;gcc、cl.exe……不是visual studio&#xff09;QT SDK&#xff08;QT SDK里面已经内置了C编译器&#xff1b;SDK就是软件…