zoukankan      html  css  js  c++  java
  • 56. Merge Intervals (Array; Sort)

    Given a collection of intervals, merge all overlapping intervals.

    For example,
    Given [1,3],[2,6],[8,10],[15,18],
    return [1,6],[8,10],[15,18].

    注意点:

    1。并不是像例子中给出的那样,前一个interval必定在后一个interval的前边。

    所以我们先要对start进行排序。必须把start小的放在前面,然后按序递增,否则会出现这样的错误

    Input:[[2,3],[4,5],[6,7],[8,9],[1,10]]
    Output:[[2,3],[4,5],[6,7],[1,10]]
    Expected:[[1,10]]
     
    2。sort start需要自定义compare函数,注意升序的时候不能定义<=,否则会造成Time Limit Exceeded
    原因是sort的compare函数必须满足strict weak ordering。时间复杂度O(nlogn), reference: http://www.cplusplus.com/reference/list/list/sort/
     
    3。两个字串长度和 =各子串长度相加的时候,如下例,并没有overlap。仅当[1,4],[4,6]才有overlap。 
    [[1,4],[5,6]]
    Output:[[1,6]]
    Expected:[[1,4],[5,6]]
    /**
     * Definition for an interval.
     * struct Interval {
     *     int start;
     *     int end;
     *     Interval() : start(0), end(0) {}
     *     Interval(int s, int e) : start(s), end(e) {}
     * };
     */
    class Solution {
    public:
        static bool compare(Interval v1, Interval v2)
        {
            if(v1.start < v2.start)
                return true;
            else if(v1.start > v2.start)
                return false;
            else
                return v1.end < v2.end;
        }
        
        vector<Interval> merge(vector<Interval>& intervals) {
            vector<Interval> result;
            if(intervals.empty()) return result;
            
            sort(intervals.begin(),intervals.end(),compare);
            result.push_back(intervals[0]);
            for(int i = 1; i < intervals.size(); i++){
                if(result[result.size()-1].end >= intervals[i].end) //totally contain
                    continue;
                    
                if(result[result.size()-1].end >= intervals[i].start){//there's overlap
                    result[result.size()-1].end = intervals[i].end;
                }
                else{ //there's no overlap
                    result.push_back(intervals[i]);
                }
            }
            
            return result;
        }
    };
  • 相关阅读:
    对spring web启动时IOC源码研究
    对volatile关键字的理解
    [书籍分享]0-009.微信营销与运营解密:利用微信创造商业价值的奥秘
    [JavaWeb基础] 002.JSP和SERVLET初级入门
    [Objective-C] 005_Category(类别)
    [PHP学习教程
    读Pyqt4教程,带你入门Pyqt4 _008
    读Pyqt4教程,带你入门Pyqt4 _007
    宝宝巴士安卓框架介绍
    [安卓基础] 006.打开另一个Activity
  • 原文地址:https://www.cnblogs.com/qionglouyuyu/p/5021123.html
Copyright © 2011-2022 走看看