AcWing 803. 区间合并

Posted qingyuyyyyy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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. 区间合并的主要内容,如果未能解决你的问题,请参考以下文章

区间合并(AcWing.803 )

AcWing 803. 区间合并

803. 区间合并

803. 区间合并(贪心)

AcWing算法基础课排序 二分 高精度 前缀和 差分 双指针 位运算 离散化 区间合并

282. 石子合并