AcWing 803. 区间合并
原题链接
简单
作者:
哈士奇最可爱
,
2021-02-20 17:06:19
,
所有人可见
,
阅读 283
#include <bits/stdc++.h>
using namespace std;
typedef pair<int,int> PII;
vector<PII> segs;
void merge(vector<PII> &segs)
{
vector<PII> res;
sort(segs.begin(),segs.end());//pair排序在c++里边会优先以左端点的值进行排序,然后再以右端点排序
int st=-2e9,ed=-2e9;
for(auto item:segs)
{
if(ed<item.first)
{
if(st!=-2e9) res.push_back({st,ed});
st=item.first,ed=item.second;
}
else ed=max(ed,item.second);
}
if(st!=-2e9) res.push_back({st,ed});//因为此题是n>=1,因此可以不写if(st!=-2e9),但如果n>=0,则必须要写if(st!=-2e9)
segs=res;
}
int main()
{
int n;
cin>>n;
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;
}