力扣 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;
}
};