博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode 695. Max Area of Island(岛屿的最大面积)
阅读量:4091 次
发布时间:2019-05-25

本文共 990 字,大约阅读时间需要 3 分钟。

 

一、问题描述

给定一个二维数组,其所有元素均为1和0,分别代表陆地和水,数组边界四周都是水,求岛屿最大面积。

 

测试用例:

Input:[[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]]Output:6Input:[[0,0,0,0,0,0,0,0]]Output:0

 

二、代码实现

二层循环遍历数组,如果当前元素是1,则计算该岛屿的面积后返回,然后与当前最大面积相比(如果比当前最大面积大,则更新最大面积),并且将岛屿的1置为0;如果当前元素是0,直接continue跳过当前元素。

class Solution {    public int maxAreaOfIsland(int[][] grid) {        if (grid == null || grid.length == 0) {            return 0;        }        int maxArea = Integer.MIN_VALUE;        for (int i=0; i
= grid.length || j < 0 || j >= grid[0].length || grid[i][j] == 0) { return 0; } int area = 1; grid[i][j] = 0; area += dfs(grid, i-1, j); //上 area += dfs(grid, i+1, j); //下 area += dfs(grid, i, j-1); //左 area += dfs(grid, i, j+1); //右 return area; }}

 

转载地址:http://ofnii.baihongyu.com/

你可能感兴趣的文章
搞定Java面试中的数据结构问题
查看>>
React Native(一):搭建开发环境、出Hello World
查看>>
Winform多线程
查看>>
Spring AOP + Redis + 注解实现redis 分布式锁
查看>>
poj 1976 A Mini Locomotive (dp 二维01背包)
查看>>
《计算机网络》第五章 运输层 ——TCP和UDP 可靠传输原理 TCP流量控制 拥塞控制 连接管理
查看>>
《PostgreSQL技术内幕:查询优化深度探索》养成记
查看>>
剑指_复杂链表的复制
查看>>
FTP 常见问题
查看>>
shell 快捷键
查看>>
MODULE_DEVICE_TABLE的理解
查看>>
No devices detected. Fatal server error: no screens found
查看>>
db db2_monitorTool IBM Rational Performace Tester
查看>>
postgresql监控工具pgstatspack的安装及使用
查看>>
swift中单例的创建及销毁
查看>>
IE不支持option的display:none属性
查看>>
[分享]mysql内置用于字符串型ip地址和整数型ip地址转换函数
查看>>
【JAVA数据结构】双向链表
查看>>
【JAVA数据结构】先进先出队列
查看>>
移植Vim配色方案到Eclipse
查看>>