(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)
    
}
相关推荐
一枝小雨3 小时前
【OJ】C++ vector类OJ题
数据结构·c++·算法·leetcode·oj题
一枝小雨3 小时前
【C++】Vector完全指南:动态数组高效使用
开发语言·c++·笔记·vector·学习笔记·std库
Tisfy3 小时前
LeetCode 3516.找到最近的人:计算绝对值大小
数学·算法·leetcode·题解
自信的小螺丝钉3 小时前
Leetcode 206. 反转链表 迭代/递归
算法·leetcode·链表
buyutang_3 小时前
C/C++ Linux系统编程:线程控制详解,从线程创建到线程终止
linux·c语言·c++·学习
liliangcsdn3 小时前
结合prompt分析NodeRAG的build过程
java·服务器·人工智能·数据分析·知识图谱
Qiang_san3 小时前
GNU Make | C/C++项目自动构建入门
c语言·c++·gnu
黑色的山岗在沉睡3 小时前
LeetCode 189. 轮转数组
java·算法·leetcode
墨染点香3 小时前
LeetCode 刷题【65. 有效数字】
算法·leetcode·职场和发展