当前位置: 首页 > news >正文

岛屿的数量(BFS)

给你一个由 '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'


class Solution {
public:int numIslands(vector<vector<char>>& grid) {if (grid.empty()) return 0;int rows = grid.size();int cols = grid[0].size();int islands = 0;int dx[] = {0, 0, -1, 1};int dy[] = {-1, 1, 0, 0};queue<pair<int,int>> q;for(int i = 0; i < rows; i++) {for(int j = 0; j < cols; j++) {  if(grid[i][j] == '1') {      // 发现陆地islands++;               // 岛屿数量加1q.push({i, j});          // 将起点加入队列grid[i][j] = '0';        // 标记为已访问while(!q.empty()) {auto [x, y] = q.front();  // 获取队首坐标q.pop();for(int k = 0; k < 4; k++) {int nx = x + dx[k];   int ny = y + dy[k];  if(nx >= 0 && nx < rows && ny >= 0 && ny < cols && grid[nx][ny] == '1') {q.push({nx, ny}); // 加入队列grid[nx][ny] = '0'; // 标记为已访问}}}}}}return islands;}
};

当遇到 '1'(未访问的陆地)时,说明发现了一个新的岛屿。用 BFS 将所有相连的陆地标记为'0'。

当遍历完后,记录了总的岛屿数量。

http://www.lryc.cn/news/545258.html

相关文章:

  • 线上JVM OOM问题,如何排查和解决?
  • Linux的缓存I/O和无缓存IO
  • 【弹性计算】弹性裸金属服务器和神龙虚拟化(三):弹性裸金属技术
  • 【MySQL】(2) 库的操作
  • Hyper-V -docker-vmware 三者的关系
  • IP-----双重发布
  • 【新立电子】探索AI眼镜背后的黑科技,FPC如何赋能实时翻译与语音识别,点击了解未来沟通的新方式!
  • LeetCode 热题 100_寻找两个正序数组的中位数(68_4_困难_C++)(二分查找)(先合并再挑选中位数;划分数组(二分查找))
  • Java多线程与高并发专题——深入ReentrantReadWriteLock
  • 【Python 语法】算法合集
  • [STM32]从零开始的STM32 BSRR、BRR、ODR寄存器讲解
  • C++ ++++++++++
  • C# 牵手DeepSeek:打造本地AI超能力
  • phpstudy安装教程dvwa靶场搭建教程
  • 最新版本SpringAI接入DeepSeek大模型,并集成Mybatis
  • FastAPI 学习笔记
  • Elasticsearch:过滤 HNSW 搜索,快速模式
  • 华为hcia——Datacom实验指南——STP工作基本原理及STP/RSTP基本功能配置
  • Vue核心知识:动态路由实现完整方案
  • 【Maui】系统找不到指定的文件Xamarin.Android.Aapt2.targets
  • 通过返回的key值匹配字典中的value值
  • 【Linux第一弹】Linux基础指令(上)
  • GitCode 助力 JeeSite:开启企业级快速开发新篇章
  • OpenCV计算摄影学(3)CUDA 图像去噪函数fastNlMeansDenoising()
  • 【react】快速上手基础教程
  • leaflet扩展插件esri-leaflet.js
  • electron-builder打包时github包下载失败【解决办法】
  • 分片加载网络图片
  • 考研复试问题总结-数据结构(1)
  • DeepSeek 助力 Vue3 开发:打造丝滑的网格布局(Grid Layout)