BZOJ.4653.[NOI2016]区间(线段树)
考虑二分。那么我们可以按区间长度从小到大枚举每个区间,对每个区间可以得到一个可用区间长度范围。
我们要求是否存在一个点被这些区间覆盖至少\(m\)次。这可以用线段树区间加、求max维护(或者在线段树上二分)。
但这是两个\(\log\)的。
我们不二分,按长度枚举每个区间。这样边枚举边判一下是否有点被覆盖\(m\)次就好了。
复杂度\(O(n\log n)\)。
动态开点值域线段树MLE 95分啊QAQ。。(必然了)
另外动态开点的区间修改,下传标记的时候要先判有没有儿子(没有要新建节点)。
因为这个浪费2h还算值吧。。
//42136kb 8316ms
#include <cstdio>
#include <cctype>
#include <algorithm>
//#define gc() getchar()
#define MAXIN 300000
#define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
const int N=5e5+5;
int ref[N<<1];
char IN[MAXIN],*SS=IN,*TT=IN;
struct Interval
{
int l,r,len;
Interval() {}
Interval(int l,int r):l(l),r(r) {len=r-l;}
bool operator <(const Interval &x)const
{
return len<x.len;
}
}A[N];
struct Segment_Tree
{
#define S N<<3
#define ls rt<<1
#define rs rt<<1|1
#define lson ls,l,m
#define rson rs,m+1,r
int tot,mx[S],tag[S];
#undef S
#define Update(x) mx[x]=std::max(mx[ls],mx[rs])
#define Upd(x,v) tag[x]+=v,mx[x]+=v
inline void PushDown(int rt)
{
Upd(ls,tag[rt]), Upd(rs,tag[rt]), tag[rt]=0;
}
void Modify(int rt,int l,int r,int L,int R,int val)
{
if(L<=l && r<=R) {Upd(rt,val); return;}
if(tag[rt]) PushDown(rt);
int m=l+r>>1;
if(L<=m) Modify(lson,L,R,val);
if(m<R) Modify(rson,L,R,val);
Update(rt);
}
}T;
inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
}
inline int Find(int x,int r)
{
int l=1,mid;
while(l<r)
if(ref[mid=l+r>>1]<x) l=mid+1;
else r=mid;
return l;
}
int main()
{
#define S 1,1,cnt
int n=read(),m=read(),t=0;
for(int i=1; i<=n; ++i) ref[++t]=read(),A[i]=Interval(ref[t-1],ref[++t]=read());
std::sort(A+1,A+1+n);
std::sort(ref+1,ref+1+t); int cnt=1;
for(int i=2; i<=t; ++i) if(ref[i]!=ref[i-1]) ref[++cnt]=ref[i];
for(int i=1; i<=n; ++i) A[i].l=Find(A[i].l,cnt), A[i].r=Find(A[i].r,cnt);
int ans=2e9;
for(int l=1,r=1; r<=n; ++r)
{
while(T.mx[1]<m && r<=n) T.Modify(S,A[r].l,A[r].r,1), ++r;
--r;
if(T.mx[1]>=m)
{
while(T.mx[1]>=m) T.Modify(S,A[l].l,A[l].r,-1), ++l;
ans=std::min(ans,A[r].len-A[l-1].len);
}
else break;
}
printf("%d\n",ans==2e9?-1:ans);
return 0;
}
动态开点:
#include <cstdio>
#include <cctype>
#include <algorithm>
#define gc() getchar()
#define MAXIN 300000
//#define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
const int N=5e5+5;
char IN[MAXIN],*SS=IN,*TT=IN;
struct Interval
{
int l,r,len;
Interval() {}
Interval(int l,int r):l(l),r(r) {len=r-l;}
bool operator <(const Interval &x)const
{
return len<x.len;
}
}A[N];
struct Segment_Tree
{
#define S N*32
#define ls son[x][0]
#define rs son[x][1]
#define lson ls,l,m
#define rson rs,m+1,r
int tot,son[S][2],mx[S],tag[S];
#undef S
#define Update(x) mx[x]=std::max(mx[ls],mx[rs])
#define Upd(x,v) tag[x]+=v,mx[x]+=v
inline void PushDown(int x)
{
if(!ls) ls=++tot; Upd(ls,tag[x]);
if(!rs) rs=++tot; Upd(rs,tag[x]);
tag[x]=0;
}
void Modify(int &x,int l,int r,int L,int R,int val)
{
if(!x) x=++tot;
if(L<=l && r<=R) {mx[x]+=val,tag[x]+=val; return;}
if(tag[x]) PushDown(x);
int m=l+r>>1;
if(L<=m) Modify(lson,L,R,val);
if(m<R) Modify(rson,L,R,val);
Update(x);
}
}T;
inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
}
int main()
{
#define S root,0,1000000000
int n=read(),m=read(),root=0;
for(int i=1,tmp; i<=n; ++i) tmp=read(),A[i]=Interval(tmp,read());
std::sort(A+1,A+1+n);
int ans=2e9;
for(int l=1,r=1; r<=n; ++r)
{
while(T.mx[root]<m && r<=n) T.Modify(S,A[r].l,A[r].r,1), ++r;
--r;
if(T.mx[root]>=m)
{
while(T.mx[root]>=m) T.Modify(S,A[l].l,A[l].r,-1), ++l;
ans=std::min(ans,A[r].len-A[l-1].len);
}
else break;
}
printf("%d\n",ans==2e9?-1:ans);
return 0;
}
BZOJ.4653.[NOI2016]区间(线段树)的更多相关文章
- BZOJ4653 [NOI2016]区间 [线段树,离散化]
题目传送门 区间 Description 在数轴上有 n个闭区间 [l1,r1],[l2,r2],...,[ln,rn].现在要从中选出 m 个区间,使得这 m个区间共同包含至少一个位置.换句话说,就 ...
- [NOI2016]区间 线段树
[NOI2016]区间 LG传送门 考虑到这题的代价是最长边减最短边,可以先把边按长度排个序,双指针维护一个尺取的过程,如果存在包含某个点的区间数\(\ge m\),就更新答案并把左指针右移,这样做的 ...
- Luogu P1712 [NOI2016]区间(线段树)
P1712 [NOI2016]区间 题意 题目描述 在数轴上有 \(N\) 个闭区间 \([l_1,r_1],[l_2,r_2],...,[l_n,r_n]\) .现在要从中选出 \(M\) 个区间, ...
- UOJ222 NOI2016 区间 线段树+FIFO队列
首先将区间按长度排序后离散化端点(这里的“长度”指的是离散化之前区间的实际长度) 然后模拟一个队列,区间按排好的顺序依次进入,直到某个点被覆盖了M次.之后依次出队,直到所有点都被覆盖小于M次 修改和询 ...
- bzoj 4653: [Noi2016]区间
Description 在数轴上有 n个闭区间 [l1,r1],[l2,r2],...,[ln,rn].现在要从中选出 m 个区间,使得这 m个区间共同包含至少一个位置.换句话说,就是使得存在一个 x ...
- BZOJ4653: [Noi2016]区间(线段树 双指针)
题意 题目链接 Sol 按照dls的说法,一般这一类的题有两种思路,一种是枚举一个点\(M\),然后check它能否成为答案.但是对于此题来说好像不好搞 另一种思路是枚举最小的区间长度是多少,这样我们 ...
- 洛谷$P1712\ [NOI2016]$区间 线段树
正解:线段树 解题报告: 传送门$QwQ$ $umm$很久以前做的了来补个题解$QwQ$ 考虑给每个区间按权值($r-l$从大往小排序,依次加入,然后考虑如果有一个位置被覆盖次数等于$m$了就可以把权 ...
- BZOJ 4653 [Noi2016]区间(Two pointers+线段树)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4653 [题目大意] 在数轴上有n个闭区间 [l1,r1],[l2,r2],...,[l ...
- BZOJ 4653: [Noi2016]区间 双指针 + 线段树
只要一堆线段有重叠次数大于等于 $m$ 次的位置,那么一定有解 因为重叠 $m$ 次只需 $m$ 个线断,将那些多余的线断排除掉即可 先将区间按照长度从小到大排序,再用 $two-pointer$ 从 ...
随机推荐
- 深入理解CMA【转】
转自:https://www.csdn.net/article/a/2016-07-07/15839383 摘要:连续内存分配(简称CMA) 是一种用于申请大量的,并且物理上连续的内存块的方法,在LW ...
- VS "以下文件中的行尾不一致,要将行尾标准化吗?"
原文地址:http://www.cnblogs.com/yymn/p/6852857.html 这是由Windows和Unix不同的标准引起的...即“回车”和“换行”的问题... “回车”和“换行” ...
- [学习笔记]Java作用域变量申明和C、C++的差异性
Java作用域 大多数程序设计语言都提供了“作用域”(Scope)的概念.对于在作用域里定义的名字,作用域同时决定了它的“可见性”以及“存在时间”.在C,C++和Java 里,作用域是由花括号的位置决 ...
- expdp和impdp 使用注意事项
使用EXPDP和IMPDP时应该注意的事项: EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用, ...
- 设置滚动条scrolltop
scrolltop用来设置页面的滚动条的位置 兼容性:链接 $().scrolltop(值)
- 从html页面中抽取table表格数据
/** * [getDataFromTrElems 获取表格行元素数据] * @param {[Object]} trElems [trs dom] * @param {[String]} type ...
- 选择一个 HTTP 状态码不再是一件难事 – Racksburg《转载》
本文转载自:众成翻译 译者:十年踪迹 链接:http://www.zcfy.cc/article/904 原文:http://racksburg.com/choosing-an-http-status ...
- python接口自动化测试三:代码发送HTTP请求
get请求: 1.get请求(无参数): 2.get请求(带参数): 接口地址:http://japi.juhe.cn/qqevaluate/qq 返回格式:json 请求方式:get post 请求 ...
- Zookeeper单机安装部署与配置(二)
在上篇博客中简单介绍了Zookeeper的特点和应用场景,详情可参考:<Zookeeper简介(一)>,那么这篇博客我们介绍一下关于Zookeeper的单机模式安装步骤与配置. 环境准备 ...
- HDU1711 Number Sequence(KMP模板题)
Number Sequence Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...