[leetcode]200.岛屿数量

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

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

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

示例 1:

输入:
11110
11010
11000
00000
输出: 1

示例 2:

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

思路:
1.定义vis数组,标记图中每个点是否被访问,初始为false,如果被访问,标记为true。
2.从第一个节点开始,找见一个没有访问的节点,进行dfs遍历,对于每个节点有上下左右四个方向,如果当前节点为1,标记vis数组对应项为true,并递归遍历其上下左右节点,直到遇到边界或当前节点为0,则返回。
3.每一次dfs遍历遍历一个连通块中的所有节点,统计共进行了多少次dfs遍历,即为答案,返回。
4.空数组特判,输出0.

AC代码:(C++)

class Solution {
   public:
    int X[4] = {0, 0, 1, -1};
    int Y[4] = {1, -1, 0, 0};
    void dfs(vector<vector<char>>& grid, vector<vector<char>>& vis, int cur_i,
             int cur_j) {
        if (cur_i < 0 || cur_i >= grid.size() || cur_j < 0 ||
            cur_j >= grid[0].size() || vis[cur_i][cur_j] == true ||
            grid[cur_i][cur_j] == '0')
            return;
        vis[cur_i][cur_j] = true;
        for (int i = 0; i < 4; i++) {
            int now_i = cur_i + X[i], now_j = cur_j + Y[i];
            // vis[now_i][now_j] = true;
            dfs(grid, vis, now_i, now_j);
        }
        return;
    }
    int numIslands(vector<vector<char>>& grid) {
        if (grid.size() == 0) return 0;
        int count = 0;
        int n = grid.size(), m = grid[0].size();
        vector<vector<char>> vis(n, vector<char>(m));
        for (int i = 0; i < n; i++) {  //初始化
            for (int j = 0; j < m; j++) {
                vis[i][j] = false;
            }
        }
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                if (vis[i][j] == false && grid[i][j] == '1') {
                    count++;
                    dfs(grid, vis, i, j);
                }
            }
        }
        return count;
    }
};

你可能感兴趣的:(LeetCode)