AcWing 803. 区间合并

2021-05-17 05:30

阅读:322

标签:sort   include   class   using   max   合并   一个   back   fir   

#include 
#include 
#include 
using namespace std;
typedef pairint, int> PII;
void merge(vector &segs) {
    vector res;
    sort(segs.begin(), segs.end());//pair排序会优先以左端点排序
    int st = -2e9, ed = -2e9;
    for (auto seg : segs)
        if (ed //没遇任何交集 ,说明找到了一个新的区间
            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;
}
int main() {
    int n;
    scanf("%d", &n);
    vector segs;
    for (int i = 0; i  ) {
        int l, r;
        scanf("%d%d", &l, &r);
        segs.push_back({l, r});
    }
    merge(segs);
    cout  endl;
    return 0;
}

 

AcWing 803. 区间合并

标签:sort   include   class   using   max   合并   一个   back   fir   

原文地址:https://www.cnblogs.com/QingyuYYYYY/p/11785053.html


评论


亲,登录后才可以留言!