AcWing 803. 区间合并
原题链接
简单
作者:
永远热爱
,
2021-03-14 22:52:24
,
所有人可见
,
阅读 309
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
typedef pair<int,int> ii;//想要存区间左端点和右端点;
vector<ii> res;
void merge(vector<ii> &res)
{
vector<ii> res2;
sort(res.begin(),res.end());//排序是因为可以直接往下区间端点比较 否则会复杂化。
int st=-2e9,ed=-2e9; //给头区间(不存在的区间) 赋值
for(auto x:res)
{
if(ed<x.first)
{
if(st!=-2e9)
res2.push_back({st,ed});
st=x.first;
ed=x.second;
}
else
ed=max(ed,x.second);
}
if(st!=-2e9) res2.push_back({st,ed});//最后一个区间也要加上去 这个容易忘
res=res2;
}
int main()
{
int n;
cin>>n;
while(n--)
{
int l,r;
cin>>l>>r;
res.push_back({l,r});
}
merge(res);
cout<<res.size()<<endl;
return 0;
}