leetcode 2943

2943: 最大化网格图中正方形空洞的面积

题干:网格由 n + 2 条水平线和 m + 2 条竖直线组成,形成++1x1 的单元格++ 。网格中的线条从 1 开始编号。返回网格中正方形空洞的最大面积。

贪心地,删的线段越多,面积越大,那就先把所有能删的线段都删掉,计算最大的矩形,长宽分别是多少。取长宽的最小值,即为正方形的边长(多删的线段撤销删除)。

以 hBars 为例:

  • 不删,最长长度是 1。
  • 删除一条线段,最长长度是 2。
  • 删除两条++编号相邻的线段++,最长长度是 3。
  • 删除三条编号连续的线段(例如 2,3,4),最长长度是 4。
  • 依此类推。

所以本题要做的是,把数组排序后,求最长连续递增子数组 的长度加一。++正方形的边长是长宽的最小值,其平方即为正方形的面积。++

复制代码
class Solution {
public:
    int maximizeSquareHoleArea(int n, int m, vector<int>& hBars, vector<int>& vBars) {
        auto f=[&](vector<int>& nums){
            int ans=1,cnt=1;
            sort(nums.begin(),nums.end());
            for(int i=1;i<nums.size();i++){
                if(nums[i]==nums[i-1]+1) ans=max(ans,++cnt);
                else cnt=1;
            }
            return ans+1;
        };
        int x=min(f(hBars),f(vBars));
        return x*x;
    }
};
相关推荐
_深海凉_1 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
踩坑记录2 小时前
leetcode hot100 寻找两个正序数组的中位数 hard 二分查找 双指针
leetcode
旖-旎2 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰2 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx2 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer2 小时前
【无标题】
开发语言·c++·算法
AGV算法笔记3 小时前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉
勤劳的进取家4 小时前
数据链路层基础
网络·学习·算法
Advancer-4 小时前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤4 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法