合并区间

一、问题描述

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

样例

给出的区间列表 => 合并后的区间列表:

[                     [
  [1, 3],               [1, 6],
  [2, 6],      =>       [8, 10],
  [8, 10],              [15, 18]
  [15, 18]            ]
]
二、解题思路

     首先,定义一个比较函数,方便用sort函数进行从小到大排序,定义vector容器,用来存储合并后的区间,定义left为新生成区间的左元素,right为新生成区间的右元素,然后开始对每个区间进行查找,若right大于等于区间开始的元素,也就是说下一个区间可以和当前的这个区间进行合并,然后令right=max(right,intervals[i].end),即进行完合并,若right小于当前区间开始的元素,直接把当前区间存入vector容器中,如此循环下去,直到查找完毕。

三、我的代码

class Solution {
public:
      static bool compare(const Interval&a,const Interval&b)
      {
          return a.start<b.start;
      }
    /**
     * @param intervals: interval list.
     * @return: A new interval list.
     */
    vector<Interval> merge(vector<Interval> &intervals) {
        // write your code here
        vector<Interval>rr;
        int n=intervals.size();
        if(n<1)
        {
            return rr;
        }
        sort(intervals.begin(),intervals.end(),compare);
        int left=intervals[0].start;
        int right=intervals[0].end;
        for(int i=1;i<n;i++)
        {
            if(intervals[i].start<=right)
            {
                right=max(right,intervals[i].end);
            }
            else
            {
                rr.push_back(Interval(left,right));
                left=intervals[i].start;
                right=intervals[i].end;
            }
        }
        rr.push_back(Interval(left,right));
        return rr;
    }
};

四、我的感想

  在编程过程中,要注意right的更新,然后是分类讨论,首先要进行对各个区间的排序,以方便之后的操作。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值