(LeetCode 面试经典 150 题) 200. 岛屿数量(深度优先搜索dfs || 广度优先搜索bfs)

题目:200. 岛屿数量


思路:bfs+dfs,两种解法。C++版本是bfs版本,JAVA和GO是dfs版本。

C++版本:

cpp 复制代码
class Solution {
public:
    typedef pair<int,int> PII;
    int fx[4]={-1,1,0,0};
    int fy[4]={0,0,-1,1};
    void dfs(int X,int Y,vector<vector<char>>& grid,vector<vector<bool>> &sta,int n,int m){
        queue<PII> qu;
        qu.push({X,Y});
        sta[X][Y]=true;
        while(qu.size()){
            PII tmp=qu.front();
            qu.pop();
            int x=tmp.first,y=tmp.second;
            for(int i=0;i<4;i++){
                int xx=x+fx[i];
                int yy=y+fy[i];
                if(xx<0||yy<0||xx>=n||yy>=m){
                    continue;
                }
                if(sta[xx][yy]==true||grid[xx][yy]=='0'){
                    continue;
                }
                sta[xx][yy]=true;
                qu.push({xx,yy});
            }
        }
        return ;
        
    }
    int numIslands(vector<vector<char>>& grid) {
        int ans=0;
        int n=grid.size(),m=grid[0].size();
        vector<vector<bool>> sta(n,vector<bool>(m,false));
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++){
                if(sta[i][j]==false && grid[i][j]=='1'){
                    dfs(i,j,grid,sta,n,m);
                    ans++;
                }
            }
        }
        return ans;
    }

};

JAVA版本:

java 复制代码
class Solution {
    void dfs(int x,int y,char[][] grid){
        if(x<0||y<0||x>=grid.length||y>=grid[0].length) return;
        if(grid[x][y]!='1') return;
        grid[x][y]='2';
        dfs(x-1,y,grid);
        dfs(x,y-1,grid);
        dfs(x,y+1,grid);
        dfs(x+1,y,grid);
    }
    public int numIslands(char[][] grid) {
        int ans=0;
        int n=grid.length,m=grid[0].length;
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++){
                if(grid[i][j]=='1'){
                    dfs(i,j,grid);
                    ans++;
                }
            }
        }
        return ans;
    }
}

GO版本:

go 复制代码
func numIslands(grid [][]byte) int {
    n,m:=len(grid),len(grid[0])
    ans:=0
    for i:=0;i<n;i++ {
        for j:=0;j<m;j++ {
            if grid[i][j]=='1' {
                dfs(i,j,&grid)
                ans++
            }
        }
    }
    return ans
}
func dfs(x,y int,grid * [][]byte) {
    if x<0||y<0||x>=len((*grid))||y>=len((*grid)[0]) {
        return
    }
    if (*grid)[x][y]!='1' {
        return
    }
    (*grid)[x][y]='2'
    dfs(x-1,y,grid)
    dfs(x+1,y,grid)
    dfs(x,y-1,grid)
    dfs(x,y+1,grid)
    
}
相关推荐
寻星探路1 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
曹牧4 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
在路上看风景4 小时前
19. 成员初始化列表和初始化对象
c++
zmzb01034 小时前
C++课后习题训练记录Day98
开发语言·c++
念风零壹4 小时前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
c++
爬山算法4 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7255 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎5 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄5 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿5 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能