AcWing 803. 区间合并

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
typedef pair<int, int> PII;
void merge(vector<PII> &segs) {
    vector<PII> res;
    sort(segs.begin(), segs.end());//pair排序会优先以左端点排序
    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;
}
int main() {
    int n;
    scanf("%d", &n);
    vector<PII> segs;
    for (int i = 0; i < n; i ++ ) {
        int l, r;
        scanf("%d%d", &l, &r);
        segs.push_back({l, r});
    }
    merge(segs);
    cout << segs.size() << endl;
    return 0;
}

 

AcWing 803. 区间合并

上一篇:Windows exit


下一篇:Windows DHCP服务器