代码随想录算法训练营Day-50 图论02 | 99.岛屿数量-深搜、99.岛屿数量-广搜 、100.岛屿的最大面积

99.岛屿数量-深搜

主函数 比较朴素:定义基础变量,接收数据,遍历图节点,对每个节点进行处理:遇到没访问过的陆地就result++,然后深搜 这篇陆地的上下左右 ,把和这片土地挨着的所有土地标记为访问过,也就是把一片岛屿都标记为访问过,之后再遍历到这片岛屿的其他陆地节点时就直接跳过了。遍历完之后,把所有的新大陆计数并搜索成岛屿,最后结果就是岛屿数量了。

深搜函数:有两种写法

一种是,终止条件显示写出,也就是终止条件判断节点是否访问过以及是否是陆地,如果不是陆地或者被访问过,那么就return,作为终止条件,然后在函数逻辑里面只进行下一个节点(上下左右)是否越界的判断;

(其实也可以把越界判断也放在终止条件里,也就是一开始判断x,y是否越界,下面递归逻辑里的下一个节点就不需要进行判断了。

cpp 复制代码
#include<iostream>
using namespace std;
#include<vector>

int dir[4][2]={0,1,1,0,-1,0,0,-1};

void dfs(vector<vector<int>>& grid, vector<vector<bool>>& visited, int x, int y){
    if(grid[x][y]==0 || visited[x][y]==true) return;
    visited[x][y] = true;
    for(int i=0;i<4;i++){
        int nextx = x+dir[i][0];
        int nexty = y+dir[i][1];
        if(nextx<0 || nextx>=grid.size() || nexty<0 || nexty>=grid[0].size()) continue;
        dfs(grid, visited, nextx, nexty);
    }
}


int main(){
    int n,m;
    cin>>n>>m;
    vector<vector<int>> grid(n,vector<int>(m));
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            cin>>grid[i][j];
        }
    }
    vector<vector<bool>> visited(n,vector<bool>(m,false));
    int result=0;
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            if(grid[i][j]==1 && visited[i][j]==0){
                result++;
                dfs(grid, visited, i, j);
            }
        }
    }
    cout<<result<<endl;
}

一种是,终止条件隐式在递归逻辑里面,由于只有符合条件(索引不越界,坐标是陆地且未被访问)的节点才会被送入下一层递归,所以其实相当于隐含了终止条件。

cpp 复制代码
#include<iostream>
using namespace std;
#include<vector>

int dir[4][2]={0,1,1,0,-1,0,0,-1};

void dfs(vector<vector<int>>& grid, vector<vector<bool>>& visited, int x, int y){
    for(int i=0;i<4;i++){
        int nextx = x+dir[i][0];
        int nexty = y+dir[i][1];
        if(nextx<0 || nextx>=grid.size() || nexty<0 || nexty>=grid[0].size()) continue;
        if(grid[nextx][nexty]==1 && visited[nextx][nexty]==false){
            visited[nextx][nexty] = true;
            dfs(grid, visited, nextx, nexty);
        }
        
    }
}


int main(){
    int n,m;
    cin>>n>>m;
    vector<vector<int>> grid(n,vector<int>(m));
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            cin>>grid[i][j];
        }
    }
    vector<vector<bool>> visited(n,vector<bool>(m,false));
    int result=0;
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            if(grid[i][j]==1 && visited[i][j]==0){
                result++;
                dfs(grid, visited, i, j);
            }
        }
    }
    cout<<result<<endl;
}

99.岛屿数量-广搜


100.岛屿的最大面积


相关推荐
Brilliantwxx1 小时前
【C++】模版进阶(特化+分离编译+非类型模版参数)
开发语言·数据结构·c++·算法
Black蜡笔小新1 小时前
自动化AI算法训练服务器DLTM企业级AI模型工作站构筑企业AI自主可控新模式
人工智能·算法·自动化
bnmoel1 小时前
数据结构深度剖析链表全集:结构实现、分类与底层原理全解析
c语言·数据结构·算法·链表·双向链表
Languorous.1 小时前
C++数据结构高阶|跳表(Skip List)深度解析:从原理到手写实现,面试高频考点全覆盖
数据结构·c++·list
许长安1 小时前
RingBuffer:面向网络编程的环形缓冲区实现
服务器·网络·c++·经验分享·笔记·缓存
Justice Young1 小时前
数据结构:邻接矩阵和邻接表的区别
数据结构
坚果派·白晓明1 小时前
【鸿蒙PC三方库移植适配框架解读系列】第六篇:关键注意事项与最佳实践
c语言·开发语言·c++·华为·harmonyos·开源鸿蒙
郝学胜-神的一滴1 小时前
中级OpenGL教程 005:为球体&平面注入法线灵魂
c++·unity·图形渲染·three.js·opengl·unreal
童先生1 小时前
华为云、阿里云、AWS签名机制详解! AK/SK + HMAC-SHA256 签名鉴权!
算法·阿里云·华为云·云计算