(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)
    
}
相关推荐
会开花的二叉树2 分钟前
上手 cpp-httplib:轻量级 C++ HTTP 库的安装与实战指南
开发语言·c++·http
Su^!-苏释州20 分钟前
Windows配置C/C++环境:MinGW+Vscode
c语言·c++·windows·vscode·大一新生学c语言
咖啡Beans23 分钟前
SpringBoot集成Clickhouse
java·spring boot
白水清风28 分钟前
【基础】关于函数式编程的知识
前端·javascript·面试
kobe_t35 分钟前
数据安全系列6:从SM4国密算法谈到Bouncy Castle
java
Nuyoah11klay41 分钟前
华清远见25072班C++学习day3
c++
從南走到北1 小时前
JAVA露营基地预约户外露营预约下单系统小程序
java·开发语言·小程序
曹牧1 小时前
Java:实现List的定长截取
java·开发语言·list
一点都不方女士1 小时前
.NET Framework 4.0.30319:官方下载与常见问题解决指南
c++·windows·.net·动态链接库·运行库
水无痕simon1 小时前
8 shiro的web整合
java