Description

定义两个区间互相匹配表示这两个区间有交集。

给出长度为N的区间序列A,M次询问,每次询问序列A中最长的连续子序列,使得子序列中的每个区间都与[L,R]互相匹配
N<=50000,M<=200000
把区间看作平面上的点(l,r)(以下均称为点以便区分)
能匹配A[a..b]的询问点在一个四分之一平面l<=min(A[a..b].r),r>=max(A[a..b].l) 上,于是可以枚举所有长度不超过sqrt(n)的子串,对每种长度的子串可以排序后和询问一起统一处理
对于更大的区间不能这样暴力处理,那么从[1,n]开始向下分治到区间[l,r],大于sqrt(n)的答案可能跨过区间中点m或在m某侧,而跨过m的可以拆成[a..m][m+1..b]两段,枚举a,b的取值,可以发现每个a或b的取值恰好使一个四分之一平面内的询问点的答案+1,排序后用树状数组处理(类似扫描线),但不同的分治区间之间答案互不影响,所以对每个分治区间要分别开一个树状数组处理。
总时间复杂度O(nsqrt(n)logn)
upd:类似http://www.cnblogs.com/ccz181078/p/6607323.html的莫队做法可以去掉一个log,实际运行效果也更好
#include<bits/stdc++.h>
const int inf=0x7fffffff;
int _(){
int x=,c=getchar();
while(c<)c=getchar();
while(c>)x=x*+c-,c=getchar();
return x;
}
int n,q,B,p2=;
int vs[][],xs[];
struct Q{
int l,r,id;
}qs[],q2[];
bool operator<(Q a,Q b){
return a.l>b.l;
}
struct Q2{
int l,r;
}q3[];
bool operator<(Q2 a,Q2 b){
return a.l>b.l;
}
int idp=,bit[][],ans[],lr[][];
void mins(int&a,int b){if(a>b)a=b;}
void maxs(int&a,int b){if(a<b)a=b;}
void calc(int l,int r){
if(r-l+<=B)return;
++idp;
int m=l+r>>;
int lmx=inf,rmn=;
for(int i=m+;i<=r;++i){
mins(lmx,vs[i][]);
maxs(rmn,vs[i][]);
q2[p2++]=(Q){lmx,rmn,idp};
}
lmx=inf,rmn=;
for(int i=m;i;--i){
mins(lmx,vs[i][]);
maxs(rmn,vs[i][]);
q2[p2++]=(Q){lmx,rmn,idp};
}
calc(l,m);
calc(m+,r);
}
void inc(int*a,int w,int mx){
for(;w<=mx;w+=w&-w)++a[w];
}
int sum(int*a,int w){
int s=;
for(;w;w-=w&-w)s+=a[w];
return s;
}
int main(){
n=_();q=_();B=sqrt(n*);
for(int i=;i<=n;++i){
xs[i]=vs[i][]=_();
vs[i][]=_();
}
std::sort(xs+,xs+n+);
for(int i=;i<=n;++i)vs[i][]=std::lower_bound(xs+,xs+n+,vs[i][])-xs;
for(int i=;i<=q;++i)qs[i].l=_(),qs[i].r=std::upper_bound(xs+,xs+n+,_())-xs-,qs[i].id=i;
std::sort(qs+,qs+q+);
calc(,n);
std::sort(q2,q2+p2);
for(int i=,p=;i<=q;++i){
for(;p<p2&&q2[p].l>=qs[i].l;++p)inc(bit[q2[p].id],q2[p].r,n+);
for(int j=;j<=idp;++j){
maxs(ans[qs[i].id],sum(bit[j],qs[i].r));
}
}
for(int i=;i<=n;++i)lr[i][]=inf;
for(int d=;d<=B;++d){
p2=;
for(int l=;l<=n;++l){
int r=l+d-;
if(r>n)break;
mins(lr[l][],vs[r][]);
maxs(lr[l][],vs[r][]);
q3[p2++]=(Q2){lr[l][],lr[l][]};
}
std::sort(q3,q3+p2);
int rmn=inf;
for(int i=,p=;i<=q;++i){
for(;p<p2&&q3[p].l>=qs[i].l;++p)mins(rmn,q3[p].r);
if(rmn<=qs[i].r)maxs(ans[qs[i].id],d);
}
}
for(int i=;i<=q;++i)printf("%d\n",ans[i]);
return ;
}

bzoj4130: [PA2011]Kangaroos的更多相关文章

  1. BZOJ4130:[PA2011]Kangaroos

    浅谈\(K-D\ Tree\):https://www.cnblogs.com/AKMer/p/10387266.html 题目传送门:https://lydsy.com/JudgeOnline/pr ...

  2. 题解 洛谷 P6349 【[PA2011]Kangaroos】

    先考虑对题目进行转化,我们称两个区间有交集为这两个区间能匹配,每个询问就是在序列中最长能连续匹配的长度. 对序列中的一个区间\([l,r]\)和询问的一个区间\([L,R]\),若满足\(L \leq ...

  3. 洛谷 P6349 - [PA2011]Kangaroos(KDT+标记下放)

    洛谷题面传送门 KDT 上打标记的 hot tea. 考虑将询问 \(A,B\) 看作二维平面直角坐标系上的一个点 \((A,B)\),那么我们这样考虑,我们从左到右扫过全部 \(n\) 个区间并开一 ...

  4. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  5. bzoj 3073: [Pa2011]Journeys -- 线段树优化最短路

    3073: [Pa2011]Journeys Time Limit: 20 Sec  Memory Limit: 512 MB Description     Seter建造了一个很大的星球,他准备建 ...

  6. 【BZOJ3073】[Pa2011]Journeys 线段树+堆优化Dijkstra

    [BZOJ3073][Pa2011]Journeys Description Seter建造了一个很大的星球,他准备建造N个国家和无数双向道路.N个国家很快建造好了,用1..N编号,但是他发现道路实在 ...

  7. BZOJ_3073_[Pa2011]Journeys_线段树优化建图+BFS

    BZOJ_3073_[Pa2011]Journeys_线段树优化建图+BFS Description Seter建造了一个很大的星球,他准备建造N个国家和无数双向道路.N个国家很快建造好了,用1..N ...

  8. Counting Kangaroos is Fun 求最少可见袋鼠数

    Description There are n kangaroos with pockets. Each kangaroo has a size (integer number). A kangaro ...

  9. bzoj3073: [Pa2011]Journeys 线段树优化建图

    bzoj3073: [Pa2011]Journeys 链接 BZOJ 思路 区间和区间连边.如何线段树优化建图. 和单点连区间类似的,我们新建一个点,区间->新点->区间. 又转化成了单点 ...

随机推荐

  1. (AS3)关于arguments

    一.官方说明 点击访问 二.使用心得 arguments包含了当前执行方法的参数,注意,不包含默认参数! arguments可以全局访问,可以在任何方法里访问,除此之外,在定义变量的时候或者初始化的时 ...

  2. mysql 关键字于数据库字段于关键字冲突的问题

    如果数据库存储字段 为MySQL关键字,那么在查询或者其他操作时会出错.那么我们应该怎么办, 可能有些人会说,换个字段不就好了啊.当然这样也是可以的,完全没问题. 然而,如果是在无法对数据库进行修改和 ...

  3. Supercell only provide the best games for players

    Supercell only provide the best games for players Supercell start to change all, Supercell's first t ...

  4. C#微信公众号开发-高级接口-之模板消息开发,附源码

    个人觉得模板消息功能的增加对公众号的作用非常大,可以说是真正意义上的实现了所谓的轻app,商家可以通过模板消息给用户发送重要的信息,交易.预约.消费.邮件.物流等信息.之前我做过的系统通过邮件发送订单 ...

  5. MVN使用随笔

    001 创建项目 mvn archetype:generate -DgroupId=com.company.push.monitor -DartifactId=push-monitor -Darche ...

  6. JVM-并发-线程安全与锁优化

    线程安全与锁优化 1.线程安全 (1)当多个线程访问一个对象时,如果不考虑这些线程在执行时环境下的调度和交替执行,也不需要进行额外的同步,或者在调用方进行任何其他的协调操作,调用这个对象的行为都可以获 ...

  7. 对比学习UIKit和AppKit -- ViewController

    在iOS中ViewController的基类是UIViewController:Mac中ViewController的基类是NSViewController. Mac中ViewController父类 ...

  8. c# List 按类的指定字段排序

      List<Report> list=Report.FindAllbyClassID(id); ) { list.Sort(delegate(Report x,Report y){ret ...

  9. Warning: Attempt to dismiss from view controller <UIViewController: 0x17d71c10> while a presentation or dismiss is in progress!

    昨天 调试程序 已经快要上线了 突然有个BUG 找了半天 才找到是因为这个警告 但是 解决这个警告又花了一天的时间 试了各种消除控制器的方法 都不可用 其中 并且 有这个bug  手机真机测试完全没问 ...

  10. Unity3D 使用C#指针unsafe

    Unsafe code requires the `unsafe' command line option to be specified 在Unity开发中,如果涉及到指针的使用,需要自己定义预处理 ...