LeetCode 252 会议室 III(Meeting Rooms III)题解与模拟面试

news2025/4/24 8:02:55

1. 引言

在现代办公和协作中,会议室的高效利用至关重要。LeetCode 252 题“会议室 III”要求我们在给定一组会议的时间区间后,计算同一时间段内需要开的最少会议室数量,以保证所有会议能顺利进行。本题不仅是经典的区间调度问题变形,也常见于资源分配、调度系统等实战场景。

标签:

  • 堆(Heap)
  • 排序(Sort)
  • 贪心(Greedy)

应用场景:

当系统中需动态分配资源(如服务器、房间、工程师),如何最小化资源数量而满足并发需求。该思路可推广到云计算资源调度、任务池管理等领域。


2. 题目描述

给定一个会议时间列表 intervals,其中 intervals[i] = [start_i, end_i] 表示第 i 场会议的开始时间和结束时间(不含结束端点)。请你计算并返回同时进行的会议的最大数量,也就是需要开的最少会议室数量。

示例函数签名(Python)

def minMeetingRooms(intervals: List[List[int]]) -> int:
    pass
  • 输入:二维整数数组 intervals,长度范围 [0, 10^4]
  • 输出:整数,最少会议室数量。

3. 示例分析

示例 1

输入:[[0,30],[5,10],[15,20]]
输出:2
  • 解释:会议 [0,30] 与 [5,10] 时间重叠,需要 2 个房间;[15,20] 可复用 [5,10] 结束的房间。

示例 2

输入:[[7,10],[2,4]]
输出:1
  • 解释:没有重叠,所有会议可在同一房间举行。

4. 问题建模与关键点

  1. 区间调度:本题属于「同时进行的区间最大重叠数」问题,经典解法是通过排序和优先队列统计并发量。
  2. 数据结构映射
    • 将每个会议的结束时间入堆,堆顶保存当前最早结束的会议。
    • 遍历开始时间,从堆中弹出所有已结束的会议,堆的大小即为当前并发会议数。

5. 解题思路

  1. 暴力枚举:对每一个分割点遍历所有区间,时间复杂度 O(n²),不推荐。
  2. 最小堆 + 排序
    • 按会议开始时间升序排序。
    • 使用最小堆维护各会议的结束时间。
    • 对每个会议,比较堆顶结束时间与当前会议开始时间:
      • 若堆顶 ≤ 当前开始,说明该会议室已空,将堆顶弹出并复用。
      • 否则需新开会议室。
    • 将当前会议的结束时间入堆。
    • 堆的大小即为所需会议室数。

为什么用堆?

  • 堆能在 O(log n) 内获得并更新最小结束时间,使整体复杂度保持 O(n log n)。

6. 算法流程

  1. intervals 为空,返回 0。
  2. 将所有会议按 start 升序排序。
  3. 初始化最小堆 heap = []
  4. 遍历 intervals
    • heap 非空且 heap[0] ≤ current_start,弹出堆顶(复用会议室)。
    • 否则无需操作(开新会议室)。
    • current_end 入堆。
  5. 遍历结束后,len(heap) 即为答案。

7. 代码实现

Python 版本

from typing import List
import heapq

def minMeetingRooms(intervals: List[List[int]]) -> int:
    if not intervals:
        return 0
    # 按开始时间排序
    intervals.sort(key=lambda x: x[0])
    # 最小堆存储会议结束时间
    heap = []
    for start, end in intervals:
        # 如果有空闲会议室
        if heap and heap[0] <= start:
            heapq.heappop(heap)
        # 将当前会议结束时间加入堆中
        heapq.heappush(heap, end)
    return len(heap)

Java 版本

import java.util.*;

class Solution {
    public int minMeetingRooms(int[][] intervals) {
        if (intervals == null || intervals.length == 0) return 0;
        Arrays.sort(intervals, Comparator.comparingInt(a -> a[0]));
        PriorityQueue<Integer> heap = new PriorityQueue<>();
        for (int[] interval : intervals) {
            if (!heap.isEmpty() && heap.peek() <= interval[0]) {
                heap.poll();
            }
            heap.offer(interval[1]);
        }
        return heap.size();
    }
}

8. 复杂度分析

  • 时间复杂度:排序 O(n log n) + 遍历 n 次,每次堆操作 O(log n),总体 O(n log n)。
  • 空间复杂度:最坏情况下所有会议重叠,堆中有 n 个元素,O(n)。

9. 边界情况 & 优化思考

  1. 空列表:直接返回 0。
  2. 单个会议:返回 1。
  3. 所有会议无重叠:堆大小最高保持 1。
  4. 大量重叠:堆大小趋近 n。
  5. 优化内存有限场景:可将结束时间存入有序数组并使用双指针,牺牲部分时间性能以节省堆空间。

10. 总结

  • 本题为区间调度经典变形,核心在于统计最大并发区间数。
  • 利用最小堆维护最早结束时间,实现 O(n log n) 解决。
  • 模板可复用于「会议室 II」「区间交集」「区间插入」等相关题目。

11. 模拟面试

在面试中,本题常作为考察区间调度与堆应用的典型题目。

面试题型示例

  1. 题目复述:给定一组会议时间区间,求所需的最少会议室数。
  2. 核心考点:区间排序、最小堆维护、复杂度分析。
  3. 扩展追问
    • 如果数据量达到 10⁸ 条,如何优化?
    • 在内存受限时,双指针法如何替代堆?
    • 多线程场景下,如何并行调度?

答题建议流程

  • 明确题意:复述输入输出,例举小规模示例。
  • 思路阐述:先讲排序,再说明堆的作用和复用机制。
  • 手写伪码:关键操作集中在堆弹出与入堆两步。
  • 复杂度分析:O(n log n) 时间,O(n) 空间。
  • 优化讨论:根据场景提出双指针、流式处理或并行方案。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2341297.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

计算机视觉算法实现——救生衣穿戴状态智能识别

✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连✨ ​​​​ ​​​​​​​​​​​​ ​​​​ 一、救生衣穿戴状态识别领域概述 水上安全一直是全球关注的重大问题&#xff0c;据世界卫生组…

Science Robotics 新型层级化架构实现250个机器人智能组队,“单点故障”系统仍可稳定运行

近期&#xff0c;比利时布鲁塞尔自由大学博士生朱炜煦与所在团队提出了一种创新的机器人群体架构——“自组织神经系统”&#xff08;SoNS&#xff0c;Self-organizing Nervous System&#xff09;。 它通过模仿自然界中的生物神经系统的组织原理&#xff0c;为机器人群体建立了…

手写深拷贝函数

在 JavaScript 中&#xff0c;深拷贝是指创建一个对象或数组的完全独立副本&#xff0c;包括其嵌套的对象或数组。这意味着修改副本不会影响原始对象。 以下是手写一个通用的深拷贝函数的实现&#xff1a; 深拷贝函数实现 function deepClone(target, map new WeakMap()) {//…

React 性能优化三剑客实战:告别无效重渲染!

在 Vue 中我们可能依赖 Vuex computed 进行状态共享和性能优化&#xff0c;而在 React 里呢&#xff1f;不需要用 Redux&#xff0c;靠 useContext、memo、useMemo 三剑客就能构建高性能组件通信方案&#xff01; &#x1f9e9; useContext 再回顾&#xff1a;状态共享不等于性…

APP动态交互原型实例|墨刀变量控制+条件判断教程

引言 不同行业的产品经理在绘制原型图时&#xff0c;拥有不同的呈现方式。对于第三方软件技术服务公司的产品经理来说&#xff0c;高保真动态交互原型不仅可以在开发前验证交互逻辑&#xff0c;还能为甲方客户带来更直观、真实的体验。 本文第三部分将分享一个实战案例&#…

色谱图QCPColorMap

一、QCPColorMap 概述 QCPColorMap 是 QCustomPlot 中用于绘制二维颜色图的类&#xff0c;可以将矩阵数据可视化为颜色图&#xff08;热力图&#xff09;&#xff0c;支持自定义色标和插值方式。 二、主要属性 属性类型描述dataQCPColorMapData存储颜色图数据的对象interpol…

最新扣子(Coze)案例教程:飞书多维表格按条件筛选记录 + 读取分页Coze工作流,无限循环使用方法,手把手教学,完全免费教程

大家好&#xff0c;我是斜杠君。 &#x1f468;‍&#x1f4bb; 星球群里有同学想学习一下飞书多维表格的使用方法&#xff0c;关于如何通过按条件筛选飞书多维表格中的记录&#xff0c;以及如何使用分页解决最多一次只能读取500条的限制问题。 斜杠君今天就带大家一起搭建一…

Spring AI Alibaba-02-多轮对话记忆、持久化消息记录

Spring AI Alibaba-02-多轮对话记忆、持久化消息记录 Lison <dreamlison163.com>, v1.0.0, 2025.04.19 文章目录 Spring AI Alibaba-02-多轮对话记忆、持久化消息记录多轮对话对话持久-Redis 本次主要聚焦于多轮对话功能的实现&#xff0c;后续会逐步增加更多实用内容&…

联邦元学习实现个性化物联网的框架

随着数据安全和隐私保护相关法律法规的出台&#xff0c;需要直接在中央服务器上收集和处理数据的集中式解决方案&#xff0c;对于个性化物联网而言&#xff0c;训练各种特定领域场景的人工智能模型已变得不切实际。基于此&#xff0c;中山大学&#xff0c;南洋理工大学&#xf…

实验1 温度转换与输入输出强化

知识点&#xff1a;input()/print()、分支语句、字符串处理&#xff08;教材2.1-2.2&#xff09; 实验任务&#xff1a; 1. 实现摄氏温度与华氏温度互转&#xff08;保留两位小数&#xff09; 2. 扩展功能&#xff1a;输入错误处理&#xff08;如非数字输入提示重新输入&#x…

【AI】SpringAI 第五弹:接入千帆大模型

1. 添加依赖 <dependency><groupId>org.springframework.ai</groupId><artifactId>spring-ai-starter-model-qianfan</artifactId> </dependency> 2. 编写 yml 配置文件 spring:ai:qianfan:api-key: 你的api-keysecret-key: 你的secr…

[Godot] C#2D平台游戏基础移动和进阶跳跃代码

本文章给大家分享一下如何实现基本的移动和进阶的跳跃&#xff08;跳跃缓冲、可变跳跃、土狼时间&#xff09;以及相对应的重力代码&#xff0c;大家可以根据自己的需要自行修改 实现效果 场景搭建 因为Godot不像Unity&#xff0c;一个节点只能绑定一个脚本&#xff0c;所以我…

【Unity笔记】Unity + OpenXR项目无法启动SteamVR的排查与解决全指南

图片为AI生成 一、前言 随着Unity在XR领域全面转向OpenXR标准&#xff0c;越来越多的开发者选择使用OpenXR来构建跨平台的VR应用。但在项目实际部署中发现&#xff1a;打包成的EXE程序无法正常启动SteamVR&#xff0c;或者SteamVR未能识别到该应用。本文将以“Unity OpenXR …

使用 rebase 轻松管理主干分支

前言 最近遇到一个技术团队的 dev 环境分支错乱&#xff0c;因为是多人合作大家各自提交信息&#xff0c;导致出现很多交叉合并记录&#xff0c;让对应 log 看起来非常混乱&#xff0c;难以阅读。 举例说明 假设我们有一个项目&#xff0c;最初develop分支有 3 个提交记录&a…

【愚公系列】《Python网络爬虫从入门到精通》063-项目实战电商数据侦探(主窗体的数据展示)

&#x1f31f;【技术大咖愚公搬代码&#xff1a;全栈专家的成长之路&#xff0c;你关注的宝藏博主在这里&#xff01;】&#x1f31f; &#x1f4e3;开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主&#xff01; &#x1f…

HttpSessionListener 的用法笔记250417

HttpSessionListener 的用法笔记250417 以下是关于 HttpSessionListener 的用法详解&#xff0c;涵盖核心方法、实现步骤、典型应用场景及注意事项&#xff0c;帮助您全面掌握会话&#xff08;Session&#xff09;生命周期的监听与管理&#xff1a; 1. 核心功能 HttpSessionLi…

火山RTC 5 转推CDN 布局合成规则

实时音视频房间&#xff0c;转推CDN&#xff0c;文档&#xff1a; 转推直播--实时音视频-火山引擎 一、转推CDN 0、前提 * 在调用该接口前&#xff0c;你需要在[控制台](https://console.volcengine.com/rtc/workplaceRTC)开启转推直播功能。<br> * 调…

Spark两种运行模式与部署

1. Spark 的运行模式 部署Spark集群就两种方式&#xff0c;单机模式与集群模式 单机模式就是为了方便开发者调试框架的运行环境。但是生产环境中&#xff0c;一般都是集群部署。 现在Spark目前支持的部署模式&#xff1a; &#xff08;1&#xff09;Local模式&#xff1a;在本地…

qt画一朵花

希望大家的生活都更加美好&#xff0c;画一朵花送给大家 效果图 void FloatingArrowPubshButton::paintEvent(QPaintEvent *event) {QPainter painter(this);painter.setRenderHints(QPainter::Antialiasing);QPen pen;pen.setColor("green");pen.setWidth(5);QBrush…

服务器上安装maven

1.安装 下载安装包 https://maven.apache.org/download.cgi 解压安装包 cd /opt/software tar -xzvf apache-maven-3.9.9-bin.tar.gz 安装目录(/opt/maven/) mv /opt/software/apache-maven-3.9.9 /opt/ 3.权限设置 把/opt/software/apache-maven-3.9.9 文件夹重命名为ma…