zoukankan      html  css  js  c++  java
  • LeetCode 200. Number of Islands 岛屿数量(C++/Java)

    题目:

    Given a 2d grid map of '1's (land) and '0's (water), count the number of islands. An island is surrounded by water and is formed by connecting adjacent lands horizontally or vertically. You may assume all four edges of the grid are all surrounded by water.

    Example 1:

    Input:
    11110
    11010
    11000
    00000
    
    Output: 1
    

    Example 2:

    Input:
    11000
    11000
    00100
    00011
    
    Output: 3

    分析:

    给定一个二维数组,其中由1(陆地)和0(水)组成,要求岛屿的数量,而岛屿则是陆地间上下左右相连后形成的,斜向的不算相连则构不成岛屿。

    遍历整个数组,当元素为1时,岛屿数目加一,此时我们要把所有与这个位置相连的陆地全部变成水(1变成0),然后继续遍历到结尾即可。

    程序:

    C++

    class Solution {
    public:
        int numIslands(vector<vector<char>>& grid) {
            if(grid.size() == 0 || grid[0].size() == 0)
                return 0;
            m = grid.size();
            n = grid[0].size();
            int res = 0;
            for(int i = 0; i < m; ++i){
                for(int j = 0; j < n; ++j){
                    if(grid[i][j] == '1'){
                        dfs(grid, i, j);
                        res++;
                    }
                }
            }
            return res;
        }
    private:
        void dfs(vector<vector<char>>& grid, int i, int j){
            if(i < 0 || j < 0 || i >= m || j >= n || grid[i][j] == '0')
                return;
            grid[i][j] = '0';
            dfs(grid, i-1, j);
            dfs(grid, i, j-1);
            dfs(grid, i+1, j);
            dfs(grid, i, j+1);
        }
        int m;
        int n;
    };

    Java

    class Solution {
        public int numIslands(char[][] grid) {
            if(grid.length == 0 || grid[0].length == 0)
                return 0;
            m = grid.length;
            n = grid[0].length;
            int res = 0;
            for(int i = 0; i < m; ++i){
                for(int j = 0; j < n; ++j){
                    if(grid[i][j] == '1'){
                        dfs(grid, i, j);
                        res++;
                    }
                }
            }
            return res;
        }
        private void dfs(char[][] grid, int i, int j){
            if(i < 0 || j < 0 || i >= m || j >= n || grid[i][j] == '0')
                return;
            grid[i][j] = '0';
            dfs(grid, i-1, j);
            dfs(grid, i, j-1);
            dfs(grid, i+1, j);
            dfs(grid, i, j+1);
        }
        private int m;
        private int n;
    }
  • 相关阅读:
    UVA10765图论+点-双连通分量性质应用
    LA4287图论+ 有向图SCC+缩点
    LA5135图论+ 割点性质运用
    LA2572计算几何+离散化+面的覆盖
    LA2402暴力枚举+计算几何+四边形面积
    UVA10566计算几何+相似三角形比例函数+二分范围的辨析
    UVA11300计算几何:正n边形内的最长的线
    UVA11524平面几何+二分法+海伦公式
    LA4986三分法求出凹性函数最小值+计算几何
    胜利大逃亡--hdu --1253(bfs)
  • 原文地址:https://www.cnblogs.com/silentteller/p/12301440.html
Copyright © 2011-2022 走看看