zoukankan      html  css  js  c++  java
  • 695. Max Area of Island

    Given a non-empty 2D array grid of 0's and 1's, an island is a group of 1's (representing land) connected 4-directionally (horizontal or vertical.) You may assume all four edges of the grid are surrounded by water.

    Find the maximum area of an island in the given 2D array. (If there is no island, the maximum area is 0.)

    Example 1:

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

    Given the above grid, return 6. Note the answer is not 11, because the island must be connected 4-directionally.

    Example 2:

    [[0,0,0,0,0,0,0,0]]

    Given the above grid, return 0.

    Note: The length of each dimension in the given grid does not exceed 50.

    dfs

    设置一个global variable area表示岛的面积。遍历数组元素,如果遇到1,把area重置为0,dfs遍历其上下左右求面积,再与max比较取较大值作为结果。

    dfs:终止条件是数组下标越界或者该点不为1。如果该点值为1,面积area增加1,把当前点赋值为0表示已访问过,然后遍历dirs数组对其上下左右的点进行同样的dfs操作。

    时间:O(M*N),空间:O(M*N) for worst case dfs recursion depth

    class Solution {
        int[][] dirs = {{-1, 0}, {0, 1}, {1, 0}, {0, -1}};  //top, right, down, left
        int area;
        
        public int maxAreaOfIsland(int[][] grid) {
            if(grid == null || grid.length == 0) return 0;
            int max = 0;
            for(int i = 0; i < grid.length; i++) {
                for(int j = 0; j < grid[0].length; j++) {
                    if(grid[i][j] == 1) {
                        area = 0;
                        dfs(grid, i, j);
                        max = Math.max(max, area);
                    }
                }
            }
            return max;
        }
        
        private void dfs(int[][] grid, int x, int y) {
            if(x < 0 || x > grid.length - 1 || y < 0 || y > grid[0].length - 1 || grid[x][y] == 0) return;
            area += 1;
            grid[x][y] = 0;
            for(int[] dir : dirs) {
                int xpos = x + dir[0];
                int ypos = y + dir[1];
                dfs(grid, xpos, ypos);
            }
        }
    }
  • 相关阅读:
    @+id/和android:id的区别
    android.intent.action.MAIN 与 android.intent.category.LAUNCHER 的验证理解
    jQuery对象与dom对象相互转换
    javascript中apply和eval结合的强大用法
    公司项目学习杂烩
    c#(winform,webform通用)利用npoi将xls文件复制为xlsx文件(excel的修改,保存,包括excel2003-office2007+的处理)
    uploadfiy使用
    我都学了些什么
    给编程一个你热爱它的机会
    野心不能成就你,热爱却可以
  • 原文地址:https://www.cnblogs.com/fatttcat/p/10058471.html
Copyright © 2011-2022 走看看