/** * struct Interval { * int start; * int end; * Interval(int s, int e) : start(start), end(e) {} * }; */ #include <vector> class Solution { public: static bool cmp(Interval a, Interval b){ return a.start < b.start;//表示小的排在前面 } vector<Interval> merge(vector<Interval>& intervals) { vector<Interval> ans; if(intervals.size() == 0) return ans; int n = intervals.size(); sort(intervals.begin(),intervals.end(),cmp); ans.push_back(intervals[0]); for(int i = 1; i < n; i++){ if(intervals[i].start <= ans.back().end)//当有重叠时 ans.back().end = max(intervals[i].end, ans.back().end); //选择两元素中大的一个 else ans.push_back(intervals[i]); } return ans; } };