前言
区间贪心问题,想到排序。
一、题目陈述
二、解决思路
将所有区间按照起点排序,然后进行贪心。
三、代码实现
#include<iostream>
#include<algorithm>
using namespace std;
typedef pair<int,int> PII;
const int N=10010;
vector<PII> segs;
int n;
void merge(vector<PII> &segs) {
vector<PII> res;
sort(segs.begin(),segs.end());
int st=-2e9,ed=-2e9+10;
//某一时刻只维护一个区间[st,ed]
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;
}
总结
区间合并问题,先排序,后合并,始终维护一个动态区间。