美文网首页
827. 最大人工岛(难度:困难)

827. 最大人工岛(难度:困难)

作者: 一直流浪 | 来源:发表于2025-02-19 23:06 被阅读0次

题目链接:https://leetcode.cn/problems/making-a-large-island/

题目描述:

给你一个大小为 n x n 二进制矩阵 grid最多 只能将一格 0 变成 1

返回执行此操作后,grid 中最大的岛屿面积是多少?

岛屿 由一组上、下、左、右四个方向相连的 1 形成。

示例 1:

输入: grid = [[1, 0], [0, 1]]
输出: 3
解释: 将一格0变成1,最终连通两个小岛得到面积为 3 的岛屿。

示例 2:

输入: grid = [[1, 1], [1, 0]]
输出: 4
解释: 将一格0变成1,岛屿的面积扩大为 4。

示例 3:

输入: grid = [[1, 1], [1, 1]]
输出: 4
解释: 没有0可以让我们变成1,面积依然为 4。

提示:

  • n == grid.length
  • n == grid[i].length
  • 1 <= n <= 500
  • grid[i][j]01

解法:标记+合并岛屿

首先我们先遍历grid中的每一块岛屿,分别利用深度优先遍历,分别向上下左右四个方向遍历并标记,计算出每块岛屿的最大面积,并且给每一块岛屿进行编号,给相连的岛屿使用相同的标号。

然后我们在遍历每一个空岛,使其填充为岛屿,,遍历其上下左右四个坐标,若坐标为岛屿,则将先前标记的标号加入到set集合中,利用set不重复的特性,自动去重,最后在里面标号取出先前计算好的面积进行相加,得到连接后的最大岛屿面积。

代码:

class Solution {
    int[] dr = new int[]{-1, 0, 1, 0};
    int[] dc = new int[]{0, -1, 0, 1};
    int[][] grid;
    int N;

    public int largestIsland(int[][] grid) {
        this.grid = grid;
        N = grid.length;

        int index = 2;
        int[] area = new int[N*N + 2];
        for (int r = 0; r < N; ++r)
            for (int c = 0; c < N; ++c)
                if (grid[r][c] == 1)
                    area[index] = dfs(r, c, index++);

        int ans = 0;
        for (int x: area) ans = Math.max(ans, x);
        for (int r = 0; r < N; ++r)
            for (int c = 0; c < N; ++c)
                if (grid[r][c] == 0) {
                    Set<Integer> seen = new HashSet();
                    for (Integer move: neighbors(r, c))
                        if (grid[move / N][move % N] > 1)
                            seen.add(grid[move / N][move % N]);

                    int bns = 1;
                    for (int i: seen) bns += area[i];
                    ans = Math.max(ans, bns);
                }

        return ans;
    }

    public int dfs(int r, int c, int index) {
        int ans = 1;
        grid[r][c] = index;
        for (Integer move: neighbors(r, c)) {
            if (grid[move / N][move % N] == 1) {
                grid[move / N][move % N] = index;
                ans += dfs(move / N, move % N, index);
            }
        }

        return ans;
    }

    public List<Integer> neighbors(int r, int c) {
        List<Integer> ans = new ArrayList();
        for (int k = 0; k < 4; ++k) {
            int nr = r + dr[k];
            int nc = c + dc[k];
            if (0 <= nr && nr < N && 0 <= nc && nc < N)
                ans.add(nr * N + nc);
        }

        return ans;
    }
}

相关文章

  • 四宝妈带娃记No21 为什么早睡这么难?

    看了一下自己的早起早睡记录,发现早期目前来说困难度不是最大的,最大的困难度是早睡。 孩子现在睡得太晚了,老三和老四...

  • 895. 最大频率栈(难度:困难)

    题目链接:https://leetcode.cn/problems/maximum-frequency-stack...

  • 827. 冬至

    诗/秦岭树 在我等待腊梅绽放时冬至的脚步悄然而至极其喜欢白皑皑中的亮红我小心翼翼地轻弹雪花 时光年年循环到这一刻我...

  • 第二章 数据结构模板

    单链表 —— 模板题 AcWing 826. 单链表 双链表 —— 模板题 AcWing 827. 双链表 栈 —...

  • 1.0、leetcode题解(javascript版)

    一、腾讯精选练习按照难度从简单到困难排列 删除链表中的节点(237) 二叉树最大深度(104) Nim游戏(292...

  • 比特币挖矿的难度和算力

    难度 难度是对挖矿困难程度的度量,即指:计算符合给定目标的一个HASH值的困难程度。 difficulty = d...

  • LeetCode 力扣 85. 最大矩形

    题目描述(困难难度) 给一个只有 0 和 1 的矩阵,输出一个最大的矩形的面积,这个矩形里边只含有 1。 解法一 ...

  • 管理是在管什么

    管理最大的难度在哪里? 谈到管理,我们第一想到的是团队太难管,领导不懂我,公司不支持,业务困难多,还有很多各种想得...

  • LeetCode 力扣 124. 二叉树中的最大路径和

    题目描述(困难难度) 考虑一条路径,可以从任意节点开始,每个节点最多经过一次,问经过的节点的和最大是多少。 解法一...

  • 活在当下的困难度

    知道但做不到,几乎是每个的通病。现在的我们是由过去的我们组成。 【大方向】 催眠(适用于大众)/冥想 注意呼吸,聆...

网友评论

      本文标题:827. 最大人工岛(难度:困难)

      本文链接:https://www.haomeiwen.com/subject/dybuortx.html