刷题253.Meeting Rooms II

一、题目说明

题目253.Meeting Rooms II,给定一列数,其中每个数表示会议开始、结束时间,计算最少需要的会议上的数量。难度是Medium!

二、我的解答

这个题目读懂后,在纸上画上坐标轴,画上各个会议时间的区间,然后从最早开始的会议开始,重叠最大部分即是最大会议室的数量。

刷题253.Meeting Rooms II_第1张图片

从“0”开始,每次遇到会议开始时间,则会议室的数量+1,遇到结束,会议室的数量-1。剩下的问题,就是设计数据结构和算法了。

可以用map实现,也可以用数组实现,也可以用堆实现。

class Solution{
	public:
		int minMeetingRooms(vector>& intervals){
			if(intervals.size()<1) return 0;
			int curRooms = 0;
			int result = 0;
			
			map dp;
			for(auto interval: intervals){
				dp[interval[0]]++;
				dp[interval[1]]--;
			}	

			for(auto iter: dp){
				curRooms = curRooms + iter.second;
				if(curRooms > result){
					result = curRooms;
				}
			}
			return result;
		}
};

三、优化措施

你可能感兴趣的:(刷题253.Meeting Rooms II)