Kimi    LeetCode 3382. 用点构造面积最大的矩形 II Python3实现
这是 LeetCode 3382. 用点构造面积最大的矩形 II 的 Python3 实现。问题分析与 3380 不同本题数据规模达到 2 \times 10^5O(n^2) 的暴力枚举会超时。需要使用 线段树Segment Tree 优化将时间复杂度降到 O(n \log n)。核心思路将所有点按 (x, y) 排序后按 x 从小到大扫描。对于当前点作为矩形右上顶点需要找1. 右下顶点前一个点必须与当前点 x 坐标相同2. 左上、左下顶点这两个 y 坐标上之前最近的点的 x 坐标必须相同3. 无内部点矩形内部不能有其他点 → 用线段树维护 y 区间内点的最大 x 坐标Python3 代码pythonimport bisectfrom typing import Listclass SegmentTree:def __init__(self, arr):self.length len(arr)self.tree self.build(arr)def feature_func(self, *args):取最大值return max(args)def build(self, arr):n len(arr)tree [0 for _ in range(2 * n)]for i in range(n):tree[i n] arr[i]for i in range(n - 1, 0, -1):tree[i] self.feature_func(tree[i 1], tree[(i 1) | 1])return treedef update(self, idx, val):单点更新idx idx self.lengthself.tree[idx] valwhile idx 1:self.tree[idx 1] self.feature_func(self.tree[idx], self.tree[idx ^ 1])idx idx 1def query_range(self, lb, rb):区间查询 [lb, rb] 的最大值if lb rb:return -1 # 空区间lb self.lengthrb self.lengthnodes []while lb rb:if lb 1 1:nodes.append(self.tree[lb])lb 1if rb 1 0:nodes.append(self.tree[rb])rb - 1lb lb 1rb rb 1if lb rb:nodes.append(self.tree[rb])return self.feature_func(*nodes)def query(self, idx):单点查询return self.tree[idx self.length]class Solution:def maxRectangleArea(self, xCoord: List[int], yCoord: List[int]) - int:points [(x, y) for x, y in zip(xCoord, yCoord)]n len(points)points sorted(points)# y坐标离散化cols sorted(set(yCoord))# 线段树维护每个y坐标上已处理点的最大x坐标初始为-1表示无点closest SegmentTree([-1 for _ in cols])ans -1for i in range(n - 1):y1_idx bisect.bisect_left(cols, points[i][1])# 当前点和下一个点x坐标相同可能作为矩形的右侧边if points[i][0] points[i 1][0]:y2_idx bisect.bisect_left(cols, points[i 1][1])# 查询两个y坐标上之前最近的点的x坐标x1 closest.query(y1_idx)x2 closest.query(y2_idx)# 左侧两个顶点的x坐标必须相同if x1 ! -1 and x2 ! -1 and x1 x2:# 计算面积S (points[i 1][1] - points[i][1]) * (points[i][0] - x1)# 检查矩形内部是否无其他点# y1_idx 和 y2_idx 之间的所有点x坐标必须都 x1# 即区间最大x x1if y2_idx - y1_idx 1 or closest.query_range(y1_idx 1, y2_idx - 1) x1:ans max(ans, S)# 处理完当前点后将其加入线段树closest.update(y1_idx, points[i][0])return ans复杂度分析- 时间复杂度O(n \log n)排序 O(n \log n)每次线段树操作 O(\log n)- 空间复杂度O(n)离散化数组和线段树关键要点1. 扫描线思想按 x 排序后已处理的点都在当前点左侧2. 线段树维护每个 y 坐标上已处理点的最大 x 坐标3. 矩形验证通过查询 (y_1, y_2) 区间内的最大 x 坐标判断矩形内部是否为空4. 面积最大化由于按 x 从小到大扫描且优先找最近的左侧点面积大的会被自然考虑此解法在 LeetCode 上可以通过耗时约 3270ms。

相关新闻

ARM嵌入式系统控制寄存器(SysCReg)配置实战:从总线仲裁到引脚复用

ARM嵌入式系统控制寄存器(SysCReg)配置实战:从总线仲裁到引脚复用

1. 系统控制寄存器:嵌入式系统的“神经中枢” 在嵌入式系统开发,尤其是基于ARM架构的微控制器项目中,我们常常会听到“寄存器配置”这个词。对于刚入行的朋友来说,这听起来可能有点抽象,甚至觉得这是芯片原厂或底层驱动…

2026/6/26 12:29:42阅读更多 →
ESP32光伏MPPT与数字电源系统设计优化

ESP32光伏MPPT与数字电源系统设计优化

1. 项目概述与核心设计思路这个基于ESP32的光伏MPPT数字可调电源项目,本质上解决的是新能源利用中的两个关键痛点:一是光伏发电效率受环境因素影响大的问题,二是传统电源系统灵活性不足的局限。我们团队在原设计基础上进行了深度改造&#xf…

2026/6/26 12:29:42阅读更多 →
Navicat密码解密终极指南:3分钟快速找回数据库连接密码

Navicat密码解密终极指南:3分钟快速找回数据库连接密码

Navicat密码解密终极指南:3分钟快速找回数据库连接密码 【免费下载链接】navicat_password_decrypt 忘记navicat密码时,此工具可以帮您查看密码 项目地址: https://gitcode.com/gh_mirrors/na/navicat_password_decrypt 你是否曾经遇到过忘记Navicat数据库连…

2026/6/26 12:29:42阅读更多 →
2026年多语言外贸网站搭建怎么做?海外独立站搭建指南

2026年多语言外贸网站搭建怎么做?海外独立站搭建指南

2026年多语言外贸网站搭建怎么做?海外独立站搭建指南多语言外贸网站搭建,不是把中文官网翻译成英文那么简单。真正能被海外客户使用的网站,要先设计信息结构,再处理语言版本、产品资料、访问速度、Google 收录、询盘表单和后续内容…

2026/6/26 13:40:12阅读更多 →
技术解析:SAI拆分APK安装器如何解决Android模块化部署的5大痛点

技术解析:SAI拆分APK安装器如何解决Android模块化部署的5大痛点

技术解析:SAI拆分APK安装器如何解决Android模块化部署的5大痛点 【免费下载链接】SAI Android split APKs installer 项目地址: https://gitcode.com/gh_mirrors/sa/SAI 在Android应用开发领域,模块化部署已成为现代应用架构的核心需求&#xff0…

2026/6/26 13:40:12阅读更多 →
OpenAI 首款自研芯片 Jalapeño 深度解析:联手 Broadcom 打造的推理之王,能否撼动 NVIDIA 霸权?

OpenAI 首款自研芯片 Jalapeño 深度解析:联手 Broadcom 打造的推理之王,能否撼动 NVIDIA 霸权?

北京时间 6 月 25 日凌晨,OpenAI 正式发布了其首款自主设计的 AI 推理芯片,代号 Jalapeo(墨西哥辣椒)。这款芯片由 OpenAI 与半导体巨头 Broadcom(博通)联合设计和制造,标志着 AI 行业从「租用 …

2026/6/26 13:40:12阅读更多 →
LinkSwift网盘直链下载助手:免费解锁8大网盘限速的终极解决方案

LinkSwift网盘直链下载助手:免费解锁8大网盘限速的终极解决方案

LinkSwift网盘直链下载助手:免费解锁8大网盘限速的终极解决方案 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云…

2026/6/26 13:40:12阅读更多 →
TWR-KL25Z开发板实战指南:从硬件解析到低功耗设计

TWR-KL25Z开发板实战指南:从硬件解析到低功耗设计

1. 项目概述:从零开始玩转TWR-KL25Z开发板如果你正在寻找一款既能让你快速上手ARM Cortex-M0,又具备强大扩展能力的入门级开发板,NXP的TWR-KL25Z绝对是一个绕不开的选择。我手头这块板子已经陪我度过了好几个嵌入式项目,从简单的L…

2026/6/26 13:40:12阅读更多 →
Mesen:终极NES模拟器指南 - 重温经典游戏的完美解决方案

Mesen:终极NES模拟器指南 - 重温经典游戏的完美解决方案

Mesen:终极NES模拟器指南 - 重温经典游戏的完美解决方案 【免费下载链接】Mesen Mesen is a cross-platform (Windows & Linux) NES/Famicom emulator built in C and C# 项目地址: https://gitcode.com/gh_mirrors/me/Mesen 还在为找不到合适的NES模拟器…

2026/6/26 13:35:11阅读更多 →
【人工智能】一文搞定到底什么是智能体

【人工智能】一文搞定到底什么是智能体

【人工智能】一文搞定到底什么是智能体 一文搞定到底什么是智能体【人工智能】一文搞定到底什么是智能体一. LM,WorkFlow,Agent分别有什么么不同二. Agent的思考过程是怎样的三. Agent的五个核心部分1)LLM2)Prompt3)Me…

2026/6/26 11:03:22阅读更多 →
嵌入式GUI控件实战:ROTARY、SCROLLBAR、SLIDER原理与应用

嵌入式GUI控件实战:ROTARY、SCROLLBAR、SLIDER原理与应用

1. 嵌入式GUI控件:从原理到实战的深度解析在嵌入式系统开发中,图形用户界面(GUI)的设计与实现往往是项目从“能用”到“好用”的关键一跃。不同于资源充沛的PC或移动平台,嵌入式设备的GUI需要在有限的CPU性能、内存空间…

2026/6/26 4:15:25阅读更多 →
Google AI Studio 300美元额度的真相与实战指南

Google AI Studio 300美元额度的真相与实战指南

1. 这300美金不是“送钱”,而是Google埋下的第一道技术门槛 你看到标题里那个醒目的“$300美金”时,第一反应可能是:又一个免费额度?领完就完事?我亲手试过——这300美金根本不是红包,而是一张入场券&…

2026/6/26 9:29:01阅读更多 →
HPE (慧与) 服务器专用 ESXi 9 全套官方定制资源详解 + 完整部署升级教程

HPE (慧与) 服务器专用 ESXi 9 全套官方定制资源详解 + 完整部署升级教程

一、前言:企业运维痛点与资源价值自博通收购 VMware 之后,原 VMware 公开免费下载渠道全面关闭,企业运维人员想要获取适配 HPE 慧与服务器的 ESXi 9 原厂镜像,必须注册博通账号、绑定有效授权才能下载,无授权账号无法获…

2026/6/26 0:02:15阅读更多 →
Kotlin的@JvmStatic与@JvmField:与Java互操作的注解

Kotlin的@JvmStatic与@JvmField:与Java互操作的注解

Kotlin作为一门现代编程语言,与Java的互操作性一直是其核心优势之一。为了让Kotlin代码能够无缝对接Java,Kotlin提供了多种注解来优化互操作体验,其中JvmStatic和JvmField是两个关键注解。它们分别用于解决静态成员和字段在Java中的访问问题&…

2026/6/26 0:02:15阅读更多 →
深入解析musl libc中的mmap实现源码

深入解析musl libc中的mmap实现源码

最近在阅读musl libc源码时,发现其mmap的实现非常精妙,特分享给大家。 一、代码整体结构 这段代码实现了__mmap函数,并通过weak_alias导出为mmap。这是典型的musl libc风格——提供弱符号以便用户可以重写。 weak_alias(__mmap, mmap); 二…

2026/6/26 0:02:15阅读更多 →