news 2026/4/20 1:47:42

LeetCode 2943.最大化网格图中正方形空洞的面积:小小思维

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 2943.最大化网格图中正方形空洞的面积:小小思维

【LetMeFly】2943.最大化网格图中正方形空洞的面积:小小思维

力扣题目链接:https://leetcode.cn/problems/maximize-area-of-square-hole-in-grid/

给你一个网格图,由n + 2横线段m + 2竖线段组成,一开始所有区域均为1 x 1的单元格。

所有线段的编号从1开始。

给你两个整数nm

同时给你两个整数数组hBarsvBars

  • hBars包含区间[2, n + 1]互不相同的横线段编号。
  • vBars包含[2, m + 1]互不相同的竖线段编号。

如果满足以下条件之一,你可以移除两个数组中的部分线段:

  • 如果移除的是横线段,它必须是hBars中的值。
  • 如果移除的是竖线段,它必须是vBars中的值。

请你返回移除一些线段后(可能不移除任何线段),剩余网格图中最大正方形空洞的面积,正方形空洞的意思是正方形内部不含有任何线段。

示例 1:

输入:n = 2, m = 1, hBars = [2,3], vBars = [2]输出:4解释:左边的图是一开始的网格图。 横线编号的范围是区间 [1,4] ,竖线编号的范围是区间 [1,3] 。 可以移除的横线段为 [2,3] ,竖线段为 [2] 。 一种得到最大正方形面积的方法是移除横线段 2 和竖线段 2 。 操作后得到的网格图如右图所示。 正方形空洞面积为 4。 无法得到面积大于 4 的正方形空洞。 所以答案为 4 。

示例 2:

输入:n = 1, m = 1, hBars = [2], vBars = [2]输出:4解释:左边的图是一开始的网格图。 横线编号的范围是区间 [1,3] ,竖线编号的范围是区间 [1,3] 。 可以移除的横线段为 [2] ,竖线段为 [2] 。 一种得到最大正方形面积的方法是移除横线段 2 和竖线段 2 。 操作后得到的网格图如右图所示。 正方形空洞面积为 4。 无法得到面积大于 4 的正方形空洞。 所以答案为 4 。

示例 3:

输入:n = 2, m = 3, hBars = [2,3], vBars = [2,3,4]输出:9解释:左边的图是一开始的网格图。 横线编号的范围是区间 [1,4] ,竖线编号的范围是区间 [1,5] 。 可以移除的横线段为 [2,3] ,竖线段为 [2,3,4] 。 一种得到最大正方形面积的方法是移除横线段 2、3 和竖线段 3、4 。 操作后得到的网格图如右图所示。 正方形空洞面积为 9。 无法得到面积大于 9 的正方形空洞。 所以答案为 9 。

提示:

  • 1 <= n <= 109
  • 1 <= m <= 109
  • 1 <= hBars.length <= 100
  • 2 <= hBars[i] <= n + 1
  • 1 <= vBars.length <= 100
  • 2 <= vBars[i] <= m + 1
  • hBars中的值互不相同。
  • vBars中的值互不相同。

解题方法:最大连续

简单换个思维,m i n ( 水平方向移除一些线后的最大连续空格 , 竖直方向移除一些线后的最大连续空格 ) min(水平方向移除一些线后的最大连续空格, 竖直方向移除一些线后的最大连续空格)min(水平方向移除一些线后的最大连续空格,竖直方向移除一些线后的最大连续空格)即为方形的最大边长。

水平方向移除一些线后的最大连续空格数是多少呢?很简单,把所有能移除的都移除呗。具体来说:

使用一个变量l a s t lastlast记录当前空格向右处理到哪条线了,使用一个变量c n t cntcnt记录当前空格的连续长度。

遍历分隔线数组,如果当前能移除的分隔线正好等于l a s t + 1 last+1last+1,则空格可以继续网友拓展(更新c n t + 1 cnt+1cnt+1,更新l a s t + 1 last+1last+1);

否则,说明上个连续空格无法拓展到这条线,更新答案最大值,并将c n t cntcnt初始化为2 22(这条线可以移除,空格长度为2),更新last为当前这条线。

  • 时间复杂度O ( h log ⁡ h + v log ⁡ v ) O(h\log h+v\log v)O(hlogh+vlogv),其中h = l e n ( h B a r s ) h=len(hBars)h=len(hBars)v = l e n ( v B a r s ) v=len(vBars)v=len(vBars)
  • 空间复杂度O ( log ⁡ h + log ⁡ v ) O(\log h+\log v)O(logh+logv),时空复杂度的主要来源都是排序,因为题目没说给定分隔线有序。

AC代码

C++
/* * @LastEditTime: 2026-01-15 10:20:39 */classSolution{private:intgetMaxDiff(vector<int>&v){intlast=1,cnt=1,ans=1;for(intt:v){if(t==last+1){cnt++;last++;}else{ans=max(ans,cnt);cnt=2;last=t;}}ans=max(ans,cnt);returnans;}public:intmaximizeSquareHoleArea(intn,intm,vector<int>&hBars,vector<int>&vBars){sort(hBars.begin(),hBars.end());sort(vBars.begin(),vBars.end());intside=min(getMaxDiff(hBars),getMaxDiff(vBars));returnside*side;}inttestGetMaxDiff(vector<int>&v){returngetMaxDiff(v);}};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 16:20:05

EchoEar喵伴智能AI开发套件的技术核心与应用展望

EchoEar喵伴智能AI开发套件是乐鑫科技与火山引擎扣子大模型团队联合打造的典型产品。其核心智能与交互能力的实现&#xff0c;高度依赖于所搭载的ESP32-S3-WROOM-1-N16R16VA模组。这款模组不仅是设备的运算中枢&#xff0c;更是其实现端侧AI、全双工语音交互等先进特性的硬件基…

作者头像 李华
网站建设 2026/4/17 20:49:25

互联网大厂Java求职面试实录:Spring Boot、微服务与AI技术全解析

互联网大厂Java求职面试实录&#xff1a;Spring Boot、微服务与AI技术全解析 本文通过互联网大厂Java求职者谢飞机与严肃面试官的三轮面试对话&#xff0c;涵盖Java核心技术栈、微服务、数据库、消息队列及AI应用场景&#xff0c;结合电商及智能客服业务&#xff0c;逐步深入&a…

作者头像 李华
网站建设 2026/4/18 7:13:26

导师严选9个AI论文工具,继续教育学生轻松搞定论文写作!

导师严选9个AI论文工具&#xff0c;继续教育学生轻松搞定论文写作&#xff01; AI 工具助力论文写作&#xff0c;高效又省心 在当今学术研究日益数字化的背景下&#xff0c;AI 工具正逐渐成为学生和科研工作者不可或缺的得力助手。尤其对于继续教育领域的学习者来说&#xff0c…

作者头像 李华
网站建设 2026/4/17 23:50:35

想自定义软件图标?试试exe图标修改器

对于希望自定义电脑上应用程序外观的用户来说&#xff0c;exe图标修改器是一个实用工具。它允许你直接替换Windows可执行文件&#xff08;.exe&#xff09;内嵌的图标资源&#xff0c;从而实现软件图标的个性化。无论是想让自己的作品更独特&#xff0c;还是想统一某个软件套装…

作者头像 李华
网站建设 2026/4/17 19:07:43

想搞懂算法效率?先弄明白递归关系的基本形式

递归关系是描述序列各项之间联系的数学方程&#xff0c;它在计算机算法分析和离散数学中扮演着核心角色。理解递归关系&#xff0c;意味着你能够洞察许多算法&#xff08;如归并排序、斐波那契数列计算&#xff09;内在的运作规律和效率本质&#xff0c;这对于优化程序性能至关…

作者头像 李华