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

区间合并

  • ①按区间左端点排序
  • ②维护一个基准(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;
}

posted @ 2020-07-02 13:40  chstor  阅读(184)  评论(0编辑  收藏  举报