区间合并
9.区间合并
区间合并

输入样例:
5
1 2
2 4
5 6
7 8
7 9
输出样例:
3
模板:
//区间合并
#include<iostream>
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
const int N = 100010;
int n;
typedef pair<int,int>PII;
vector<PII> segs;
//双指针
void merge(vector<PII> &segs){
vector<PII> res;
sort(segs.begin(),segs.end()); //C++默认先以 first 排序再以 second 排序
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(){
cin>>n;
for(int i=0;i<n;i++){
int l,r;
cin>>l>>r;
segs.push_back({l,r});
}
merge(segs);
cout<<segs.size()<<endl;
return 0;
}

浙公网安备 33010602011771号