洛谷P3602 Koishi Loves Segments(贪心,multiset)

洛谷题目传送门

贪心小水题。

把线段按左端点从小到大排序,限制点也是从小到大排序,然后一起扫一遍。

对于每一个限制点实时维护覆盖它的所有线段,如果超过限制,则贪心地把右端点最大的线段永远删去,不计入答案。显然这样做对后面的决策更有利。

以右端点为键值,需要资瓷动态插入,删除最小值、最大值,multiset就行了。

代码很短,常数应该比较大,但不知为何暂时混了个rk1。

#include<bits/stdc++.h>
#define R register int
#define G if(++ip==ie)if(fread(ip=buf,1,SZ,stdin))
using namespace std;
const int SZ=1<<19,N=4e5+9;
char buf[SZ],*ie=buf+SZ,*ip=ie-1;
inline int in(){
	G;while(*ip<'-')G;
	R f=*ip=='-';if(f)G;
	R x=*ip&15;G;
	while(*ip>'-'){x*=10;x+=*ip&15;G;}
	return f?-x:x;
}
struct Seg{
	int x,y;
	inline bool operator<(const Seg&a)const{
		return x<a.x;
	}
}a[N],b[N];
multiset<int>s;
int main(){
	R n=in(),m=in(),ans=n;
	for(R i=0;i<n;++i)a[i].x=in(),a[i].y=in();
	for(R i=0;i<m;++i)b[i].x=in(),b[i].y=in();
	sort(a,a+n);sort(b,b+m);
	for(R i=0,j=0;i<m;++i){
		while(j<n&&a[j].x<=b[i].x)s.insert(a[j++].y);
		while(s.size()&&*s.begin()<b[i].x)s.erase(s.begin());
		while(s.size()>b[i].y)s.erase(--s.end()),--ans;
	}
	return cout<<ans<<endl,0;
}
posted @   Flash_Hu  阅读(338)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示
西雅图
17:14发布
西雅图
17:14发布
6°
东南风
3级
空气质量
相对湿度
84%
今天
3°/13°
周六
小雨
6°/15°
周日
中雨
4°/15°