码迷,mamicode.com
首页 > 其他好文 > 详细

252.Meeting Rooms

时间:2016-06-21 10:46:15      阅读:102      评论:0      收藏:0      [点我收藏+]

标签:

    /*
     * 252.Meeting Rooms
     * 2016-6-20 by Mingyang
     * Arrays.sort的用法要熟悉
     * 这题和Merge Intervals很像,我们按开始时间把这些Interval都给排序后,就挨个检查是否有冲突就行了。
     * 有冲突的定义是开始时间小于之前最晚的结束时间。
     * 这里之前最晚的结束时间不一定是上一个的结束时间,所以我们更新的时候要取最大值。
     */
     public boolean canAttendMeetings(Interval[] intervals) {
            if(intervals == null || intervals.length == 0) return true;
            Arrays.sort(intervals, new Comparator<Interval>(){
                public int compare(Interval i1, Interval i2){
                    return i1.start - i2.start;
                }
            });
            int end = intervals[0].end;
            // 检查每一个Interval
            for(int i = 1; i < intervals.length; i++){
                // 如果Interval的开始时间小于之前最晚的结束时间,就返回假
                if(intervals[i].start < end) return false;
                end = Math.max(end, intervals[i].end);
            }
            return true;
        }

 

252.Meeting Rooms

标签:

原文地址:http://www.cnblogs.com/zmyvszk/p/5602677.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!