当前位置:网站首页>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;
}
边栏推荐
- AlphaFold 如何实现 AI 在结构生物学中的全部潜力
- 职场漫谈:为什么越是内卷的行业越有人争着抢着往里冲?好奇怪的说...
- B. Construct a simple sequence (greedy)
- LCP 06. 拿硬币-遍历
- 编程思想_编程有必要给孩子学吗?
- Chinese valentine's day, of course, to learn SQL optimization better leave work early to find objects
- 【历史上的今天】8 月 4 日:第一位图灵奖女性得主;NVIDIA 收购 MediaQ;首届网络安全挑战大赛完成
- 代码随想录笔记_动态规划_1049最后一块石头的重量II
- CCF GLCC officially opened | Kyushu Cloud open source experts bring generous bonuses to help universities promote open source
- 第六届未来网络发展大会,即将开幕!
猜你喜欢

MySQL【触发器】

JCMsuite应用:倾斜平面波传播透过光阑的传输

Sum of four squares, laser bombs

解题-->在线OJ(十八)

Lixia Action | Kyushu Yunzhang Jinnan: Open source is not a movement for a few people, popularization is the source

九州云出席领航者线上论坛,共话5G MEC边缘计算现状、挑战和未来

Database recovery

Unity插件:使用PopulationSystem制作行走交流的路人

【 HMS core 】 【 Media 】 online video editing service 】 【 material can't show, or network anomalies have been Loading state

idea去掉spark的日志
随机推荐
快解析结合千方百剂
自监督学习未来是掩码自编码器?KAIST最新《自监督学习掩码自编码器》研究进展
物联网应用发展趋势
文盘Rust -- 配置文件解析
C# winforms 输入颜色转换颜色名
Why does the decimal point appear when I press the space bar in word 2003?
化算力为战力:宁夏中卫的数字化转型启示录
1375. 二进制字符串前缀一致的次数-前序遍历法
本周讨论用户体验:Daedalus 的 Nemo 加入 Ambire,探索加密海洋
谷歌插件.crx文件下载后被自动删除的解决方法
节省50%成本!京东云重磅发布新一代混合CDN产品
Convolutional Neural Network Basics
相似文本聚类与调参
电子行业MES管理系统有哪些特殊功能
基于 Next.js实现在线Excel
Lixia Action | Kyushu Yunzhang Jinnan: Open source is not a movement for a few people, popularization is the source
"C pitfalls and pitfalls" reading summary
License server system does not support this version of this feature
两款移相振荡器的对比
How to write SQL statements: the usage of Update, Case, and Select together