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

力扣HOT100之图论:200. 岛屿数量


这道题虽然在力扣上没做过,但是之前刷代码随想录的时候在卡码网上刷过,属于是图论的入门模板题,可以参考我之前的这篇博客,里面的思路写的还是挺详细的。我们需要定义一个方向数组,对应着4个移动方向,另外,我们还需要定义dfs函数来探索岛屿,在地图上移动的过程中,当我们遇到一块从未遇到的陆地时,我们就调用dfs函数来探索这块陆地,dfs函数的作用就是将当前陆地所在的岛屿全部探索出来,因此,在主函数中,但凡遇到新的陆地,那一定是新的岛屿上的陆地,直接将岛屿数量+1即可。

class Solution {
public:int numIslands(vector<vector<char>>& grid) {int result = 0;//定义四个搜索方向vector<vector<int>> dirs = {  //定义4个搜索方向{0, 1},  //向右{0, -1}, //向左{-1, 0}, //向上{1, 0}   //向下};vector<vector<bool>> visited(grid.size(), vector<bool>(grid[0].size(), false));//定义深度优先搜索函数auto dfs = [&] (this auto&& dfs, vector<vector<char>>& grid, vector<vector<bool>>& visited, int x, int y) -> void{//输入参数分别为:陆地和水的矩阵、已经探索过的陆地,当前位置的x,y坐标for(auto dir : dirs){int next_x = x + dir[0];int next_y = y + dir[1];if((next_x < 0 || next_x >= grid.size()) || next_y < 0 || next_y >= grid[0].size())continue;   //访问越界,直接跳过//到达新的陆地if(!visited[next_x][next_y] && grid[next_x][next_y] == '1'){visited[next_x][next_y] = true;dfs(grid, visited, next_x, next_y);}}};for(int i = 0; i < grid.size(); i++){for(int j = 0; j < grid[0].size(); j++){if(!visited[i][j] && grid[i][j] == '1'){dfs(grid, visited, i, j);result++;}}}return result;}
};
http://www.xdnf.cn/news/8301.html

相关文章:

  • 【LangChain大模型应用与多智能体开发 ① 初识LangChain 】
  • 用户意图识别模块
  • 跟Gemini学做PPT:字号选择
  • MyBatisPlus使用教程
  • Ubuntu 上进行树莓派交叉编译
  • hadoop 无法存储数据到hbase里面 已经解决
  • 鸿蒙仓颉开发语言实战教程:实现商城应用详情页
  • SpringBoot Day_03|数据校验|异常处理|日志级别|定时器
  • Java使用CollectionUtils集合工具类
  • 大模型相关数据格式及训练器接收的数据格式
  • 云南安全员考试报名需要具备哪些条件?
  • 【深度学习-Day 15】告别“盲猜”:一文读懂深度学习损失函数
  • VSCode C/C++ 开发环境完整配置及一些扩展用途(自用)update:2025/3/31
  • 英语学习5.21
  • 【项目记录】部门增删改及日志技术
  • 超声仿真乳腺体模的主要声学参数
  • 3 PID控制学习指南
  • el-form elform 对齐方式调整
  • mysql安全管理
  • 【C/C++】虚拟内存空间问题整理_可用于验证掌握情况
  • WebTransport 低延迟通信
  • 解决SQL Server SQL语句性能问题(9)——创建和更新统计对象
  • Spring的事务传播行为
  • PCB设计教程【入门篇】——电路分析基础-电路定理
  • tf 重排 切分 逆排列
  • mysql日志文件binlog分析记录
  • 结构性断裂:中年失业潮与婚姻解体的崩溃逻辑
  • 数学基础知识:三角函数
  • 【打卡】车厢重排
  • java后端-海外登录(谷歌/FaceBook/苹果)