leetcode695 岛屿的最大面积

题目

给你一个大小为 m x n 的二进制矩阵 grid 。

岛屿 是由一些相邻的 1 (代表土地) 构成的组合,这里的「相邻」要求两个 1 必须在 水平或者竖直的四个方向上 相邻。你可以假设 grid 的四个边缘都被 0(代表水)包围着。

岛屿的面积是岛上值为 1 的单元格的数目。

计算并返回 grid 中最大的岛屿面积。如果没有岛屿,则返回面积为 0 。

示例

输入:grid = [[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]]
输出:6
解释:答案不应该是 11 ,因为岛屿只能包含水平或垂直这四个方向上的 1 。
在这里插入图片描述

示例

这道题和上一道求岛屿数量的题目,在思想上都是一样的,就是通过dfs来遍历到每个岛屿,同时计算出它的面积来,维护一个面积的最大值即可

func maxAreaOfIsland(grid [][]int) int {
	var dfs func(grid [][]int, i, j int) int
	dfs = func(grid [][]int, i, j int) int {
		if i < 0 || j < 0 || i >= len(grid) || j >= len(grid[0]) || grid[i][j] == 0 {
			return 0
		}
		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
	}
	maxArea := 0
	for i := 0; i < len(grid); i++ {
		for j := 0; j < len(grid[0]); j++ {
			if grid[i][j] == 1 {
				maxArea = max(maxArea, dfs(grid, i, j))
			}
		}
	}
	return maxArea
}

最近更新

  1. TCP协议是安全的吗?

    2024-06-14 09:34:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-14 09:34:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-14 09:34:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-14 09:34:03       18 阅读

热门阅读

  1. 揭开 Docker 容器的神秘面纱:深入理解容器原理

    2024-06-14 09:34:03       9 阅读
  2. adb简单使用命令

    2024-06-14 09:34:03       6 阅读
  3. Leetcode.2862 完全子集的最大元素和

    2024-06-14 09:34:03       6 阅读
  4. flume配置----a1.sources.r1.positionFile=xxxx.json

    2024-06-14 09:34:03       8 阅读
  5. 【安全函数】常用的安全函数的使用

    2024-06-14 09:34:03       6 阅读
  6. 快速入门Flutter:从零开始构建你的第一个应用

    2024-06-14 09:34:03       6 阅读