博客
关于我
【Lintcode】919. Meeting Rooms II
阅读量:202 次
发布时间:2019-02-28

本文共 1913 字,大约阅读时间需要 6 分钟。

题目地址:

给定一系列会议的开始和结束时间组成的数组,会议时长都是大于 0 0 0的。问最少需要多少个会议室。

思路是扫描线。参考。先开一个pair类,存两个变量,一个存时间,另一个存”开始还是结束“。然后将所有时间点封装成这个类,加入一个列表后排序。接着遍历这些pair,如果是开始,则计数就加一,否则就减一,同时更新最大同时正在开的会议的数量即可。注意,由于如果同一个时间有多个会议同时开始结束,要把结束的pair排在前面,这样遍历到这个时间点的时候,会先把结束的会议减去,再加上新开始的会议。

算法正确性证明:

首先,算法得到的是同一时间正在开的会议最多的数量。显然会议室至少要这么多个。我们直接构造出使用这么多数量的会议室的方案即可。方案如下:先按照开始时间对会议排序。接着扫描所有会议。遇到了新的会议,如果没有空闲会议室,则给它安排一个新会议室;否则将空闲的会议室开给它。这样的开会议室的方法得到的会议室数量恰好是同一时刻正在开的会议的数量。所以算法正确。

代码如下:

import java.util.ArrayList;import java.util.List;public class Solution {           class Pair {           int time;        // flag为0表示结束,1表示开始        int flag;            public Pair(int time, int flag) {               this.time = time;            this.flag = flag;        }    }        /**     * @param intervals: an array of meeting time intervals     * @return: the minimum number of conference rooms required     */    public int minMeetingRooms(List
intervals) { // Write your code here if (intervals == null || intervals.isEmpty()) { return 0; } List
list = new ArrayList<>(); for (Interval interval : intervals) { list.add(new Pair(interval.start, 1)); list.add(new Pair(interval.end, 0)); } // 按时间排序;时间相等则会议结束的排在前面,开始的排在后面 list.sort((p1, p2) -> p1.time != p2.time ? Integer.compare(p1.time, p2.time) : Integer.compare(p1.flag, p2.flag)); int res = 0, count = 0; for (Pair pair : list) { if (pair.flag == 1) { count++; } else { count--; } res = Math.max(res, count); } return res; }}class Interval { int start, end; public Interval(int start, int end) { this.start = start; this.end = end; }}

时间复杂度 O ( n log ⁡ n ) O(n\log n) O(nlogn),空间 O ( n ) O(n) O(n)

转载地址:http://xzcs.baihongyu.com/

你可能感兴趣的文章
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>