AcWing 803. 区间合并
原题链接
简单
作者:
逃离这世俗
,
2022-07-04 17:04:03
,
所有人可见
,
阅读 133
/*定义一个区间,有一个正在维护的区间和正在枚举的区间
比较维护区间的右端点与枚举区间的左端点比较*/
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
typedef pair<int,int>PII;
int n;
vector<PII>segs;
void merge(vector<PII>&segs){
//定义一个存储答案的vector
vector<PII>res;
//排序左端点,pair优先排序first
sort(segs.begin(),segs.end());
//定义区间为负无穷
int st=-2e9,ed=-2e9;
//遍历segs,所有区间
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;
}