当前位置:网站首页>leetcode:253. 至少需要多少间会议室
leetcode:253. 至少需要多少间会议室
2022-08-04 14:31:00 【OceanStar的学习笔记】
题目来源
题目描述
题目解析
最小堆
分析:
- 这里一定要把所有会议全部安排完,所以一定需要遍历这些数组
- 首先,一堆会议时间是杂乱无章的,为了让其有序,我们可以将其排序,那么问题是以起始时间排序还是以终止时间排序?
- 思考,这道题我们要解决的问题是:当观察到一个会议时,需不需要另外安排会议室?
- 从这个思路来看,我们考虑的顺序是按照会议开始的时间,因此这里按照会议起始的时间来排序
- 排序后遇到的另一个问题是,当一个新会议开始的时候,我们要怎么确定这个时候是否有之前空出来的会议室
- 因此我们还要对会议的结束时间进行统计,每当一个会议开始,我们就去检查这个会议之前开始的会议的结束时间的最小值。所以我们可以维护一个最小堆用于记录结束时间。
小结:
- 先按照开始时间对这些数组进行排序
- 然后准备一个最小堆,这个最小堆维护的是当前会议之前开始的会议的结束时间。怎么维护呢?
int minMeetingRooms(std::vector<std::vector<int>>intervals){
if(intervals.empty()){
return 0;
}
int minRooms = 0;
std::sort(intervals.begin(), intervals.end(), [](std::vector<int> &l, std::vector<int> &r){
return l[0] < r[0];
});
std::priority_queue<int, std::vector<int>, std::greater<>> pq;
// 第一个会议肯定是需要排序的
pq.emplace(intervals[0][1]);
for (int i = 1; i < intervals.size(); ++i) {
// 有一个会议室空出来了
if(intervals[i][0] >= pq.top()){
// 如果当前会议start >= 之前的end
pq.pop(); // 把之前的房间空出来
}
pq.emplace(intervals[i][1]);
}
return minRooms;
}
边栏推荐
- Rust 从入门到精通04-变量
- 开发者独立搭建一个跨模态搜索应用有多难?
- 基于 Next.js实现在线Excel
- 爬虫——动作链、xpath、打码平台使用
- Oracle RAC环境下vip/public/private IP的区别
- 代码随想录笔记_动态规划_1049最后一块石头的重量II
- 在腾讯,我的试用期总结!
- 中大型商业银行堡垒机升级改造就用行云管家!必看!
- [LeetCode] 38. Appearance sequence
- 【 HMS core 】 【 Media 】 online video editing service 】 【 material can't show, or network anomalies have been Loading state
猜你喜欢
随机推荐
Centos7 install mysql version rapidly
本周讨论用户体验:Daedalus 的 Nemo 加入 Ambire,探索加密海洋
[The Art of Hardware Architecture] Study Notes (1) The World of Metastability
ICML 2022 | 图神经网络的局部增强
MySQL【触发器】
技术分享| 融合调度系统中的电子围栏功能说明
【剑指offer33】二叉搜索树的后序遍历序列
【模型部署与业务落地】基于量化芯片的损失分析
LCP 06. 拿硬币-遍历
SLAM 04.视觉里程计-1-相机模型
C# winforms 输入颜色转换颜色名
基于 Next.js实现在线Excel
zabbix自定义图形
Rust from entry to proficient 04-variables
C# 动态加载卸载 DLL
How to write SQL statements: the usage of Update, Case, and Select together
杭电校赛(逆袭指数)
开发者独立搭建一个跨模态搜索应用有多难?
Keycloak 6.0.0 正式发布,身份和访问管理系统
【问题解决】QT更新组件出现 “要继续此操作,至少需要一个有效且已启用的储存库”