BFS 力扣 200.岛屿数量

力扣 200.岛屿数量

给你一个由 ‘1’(陆地)和 ‘0’(水)组成的的二维网格,请你计算网格中岛屿的数量。

岛屿总是被水包围,并且每座岛屿只能由水平方向或竖直方向上相邻的陆地连接形成。

此外,你可以假设该网格的四条边均被水包围。

示例 1:
输入:

[
['1','1','1','1','0'],
['1','1','0','1','0'],
['1','1','0','0','0'],
['0','0','0','0','0']
]

输出:

1

示例 2:

输入:

[
['1','1','0','0','0'],
['1','1','0','0','0'],
['0','0','1','0','0'],
['0','0','0','1','1']
]

输出:

3

解释: 每座岛屿只能由水平和/或竖直方向上相邻的陆地连接而成。

思路:
遍历整个二维网格,遇到岛屿时将坐标插入队列中,然后从队首开始逐步搜索,搜索后弹出对首,遇到陆地便插入队列,并标记其坐标,队列为空后岛屿数量加一。
代码:

class Solution
{
    
    
public:
    int numIslands(vector<vector<char>> &grid)
    {
    
    
        int b = grid.size();
        if (!b)
            return 0;
        int a = grid[0].size();

        int ans = 0;
        for (int i = 0; i < b; i++)
        {
    
    
            for (int j = 0; j < a; j++)
            {
    
    
                if (grid[i][j] == '1')
                {
    
    
                    ans++;
                    grid[i][j] = '0';
                    queue<pair<int, int>> ngb;
                    ngb.push({
    
    i, j});
                    while (!ngb.empty())
                    {
    
    
                        auto x = ngb.front();
                        ngb.pop();
                        int row = x.first, col = x.second;
                        if (row - 1 >= 0 && grid[row - 1][col] == '1')
                        {
    
    
                            ngb.push({
    
    row - 1, col});
                            grid[row - 1][col] = '0';
                        }
                        if (row + 1 < b && grid[row + 1][col] == '1')
                        {
    
    
                            ngb.push({
    
    row + 1, col});
                            grid[row + 1][col] = '0';
                        }
                        if (col - 1 >= 0 && grid[row][col - 1] == '1')
                        {
    
    
                            ngb.push({
    
    row, col - 1});
                            grid[row][col - 1] = '0';
                        }
                        if (col + 1 < a && grid[row][col + 1] == '1')
                        {
    
    
                            ngb.push({
    
    row, col + 1});
                            grid[row][col + 1] = '0';
                        }
                    }
                }
            }
        }
        return ans;
    }
};

猜你喜欢

转载自blog.csdn.net/qq_46039856/article/details/108417020