253. Meeting Rooms II 会议室 II

2021-09-09  本文已影响0人  justonemoretry
image.png

解法

public class Struct253 {

    public class Interval {
        int start;
        int end;

        Interval() {
            start = 0;
            end = 0;
        }

        Interval(int s, int e) {
            start = s;
            end = e;
        }
    }

    public int minMeetingRooms(Interval[] intervals) {
        // 按区间的start左侧排序,实现Comparator接口
        Arrays.asList(intervals, new Comparator<Interval>() {
            @Override
            public int compare(Interval o1, Interval o2) {
                return o1.start - o2.start;
            }
        });

        // 小顶堆
        PriorityQueue<Integer> pq = new PriorityQueue<>();
        for (int i = 0; i < intervals.length; i++) {
            // 开始时间大于前面结束时间的最小值,说明后面的时间段也都是这样,前面已经按开始时间排序了
            // 说明可以和这个共用一个会议室,弹出
            if (!pq.isEmpty() && intervals[i].start >= pq.peek()) {
                pq.poll();
            }
            pq.offer(intervals[i].end);
        }
        return pq.size();
    }
}
上一篇 下一篇

猜你喜欢

热点阅读