lintcode 156. 合并区间

亡梦爱人 提交于 2020-01-10 18:43:36

给出若干闭合区间,合并所有重叠的部分。

样例
样例1:

输入: [(1,3)]
输出: [(1,3)]
样例 2:

输入:  [(1,3),(2,6),(8,10),(15,18)]
输出: [(1,6),(8,10),(15,18)]
挑战
O(n log n) 的时间和 O(1) 的额外空间。
/**
 * Definition of Interval:
 * classs Interval {
 *     int start, end;
 *     Interval(int start, int end) {
 *         this->start = start;
 *         this->end = end;
 *     }
 * }
 */

class Solution {
public:
    /**
     * @param intervals: interval list.
     * @return: A new interval list.
     */ 
    static bool cmp(const Interval &a,const Interval &b)
    {
        return a.start<b.start;
    }
    vector<Interval> merge(vector<Interval> &intervals) {
        // write your code here
        if(intervals.size()<=0) return intervals;
        sort(intervals.begin(),intervals.end(),cmp);
        vector<Interval> res;
        res.push_back(intervals[0]);
        for (int i = 1; i < intervals.size(); i++) {
            /* code */
            if(intervals[i].start<=res.back().end)
                res.back().end=(res.back().end > intervals[i].end) ? res.back().end : intervals[i].end;
            else res.push_back(intervals[i]);
        }
        return res;
    }
   
};
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!