首页 > Windows开发 > 详细

ACwing(基础)--- 区间合并

时间:2020-07-02 14:54:46      阅读:82      评论:0      收藏:0      [点我收藏+]

区间合并

  • ①按区间左端点排序
  • ②维护一个基准(st-ed)
// 将所有存在交集的区间合并
void merge(vector<PII> &segs)
{
    vector<PII> res;

    sort(segs.begin(), segs.end());

    int st = -2e9, ed = -2e9;
    for (auto seg : segs)
        if (ed < seg.first)
        {
            if (st != -2e9) res.push_back({st, ed});
            st = seg.first, ed = seg.second;
        }
        else ed = max(ed, seg.second);

    if (st != -2e9) res.push_back({st, ed});

    segs = res;
}

ACwing(基础)--- 区间合并

原文:https://www.cnblogs.com/bingers/p/13224214.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!