浅谈\(K-D\ Tree\):https://www.cnblogs.com/AKMer/p/10387266.html

题目传送门:https://lydsy.com/JudgeOnline/problem.php?id=4130

这题跟\(BZOJ4358:permu\)一样。

不过我们需要把区间包含某个点改成判断区间是否有交点。

假设我们有俩区间\([l,r]\)与\([L,R]\)

假设俩不相交则满足:\(r<L||l>R\);

假设有交:\(l<=R\)且\(L<=r\)

我们把询问区间当做点,把序列区间一个一个往\(K-D\)树里面搞。

那么就可以看做是把正交包围盒\([1,R][L,inf]\)。所以判断相交或者不相交就直接变成正交包围盒范围查询了。

判断不交的时候用大区间\([mn[0],mx[1]]\),判断相交的时候用小区间\([mx[0],mn[1]]\)。由于卡常需求比较高,我就把\(struct\)改成\(namespace\)了。

时间复杂度:\(O(n\sqrt{n})\)

空间复杂度:\(O(n)\)

代码如下:

#include <cstdio>
#include <algorithm>
using namespace std; const int maxn=5e4+5,maxm=2e5+5,inf=2e9; int ans[maxm];
int n,m,pps,X1,X2,Y1,Y2,L,R; int read() {
int x=0,f=1;char ch=getchar();
for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
for(;ch>='0'&&ch<='9';ch=getchar())x=x*10+ch-'0';
return x*f;
} struct Kangaroos {int l,r;}a[maxn]; namespace T {
int root;
bool bo[maxm];
int cnt[maxm],hismx[maxm];
int add[maxm],cov[maxm],hiscov[maxm]; struct point {
int id,ls,rs;
int c[2],mn[2],mx[2]; bool operator<(const point &a)const {
return c[pps]<a.c[pps];
}
}p[maxm]; int build(int l,int r,int d) {
int mid=(l+r)>>1,u=mid;pps=d;
nth_element(p+l,p+mid,p+r+1);
if(l<mid)p[u].ls=build(l,mid-1,d^1);
if(r>mid)p[u].rs=build(mid+1,r,d^1);
int ls=p[u].ls,rs=p[u].rs;
for(int i=0;i<2;i++) {
int mn=min(p[ls].mn[i],p[rs].mn[i]);
p[u].mn[i]=min(p[u].c[i],mn);
int mx=max(p[ls].mx[i],p[rs].mx[i]);
p[u].mx[i]=max(p[u].c[i],mx);
}
return u;
} void prepare() {
p[0].mn[0]=p[0].mn[1]=inf;
p[0].mx[0]=p[0].mx[1]=-inf;
for(int i=1;i<=m;i++)
p[i].c[0]=read(),p[i].c[1]=read(),p[i].id=i;
root=build(1,m,0);
} void cov_tag(int u) {
if(!bo[u])bo[u]=1,hiscov[u]=0;
cnt[u]=cov[u]=0;
} void add_tag(int u,int v) {
if(!bo[u])add[u]+=v;
else cov[u]+=v,hiscov[u]=max(hiscov[u],cov[u]);
cnt[u]+=v,hismx[u]=max(hismx[u],cnt[u]);
} void solve(int u,int v,int hisv) {
bo[u]=1,hiscov[u]=max(hiscov[u],hisv);
cnt[u]=cov[u]=v;
hismx[u]=max(hismx[u],hiscov[u]);
} void push_down(int u) {
if(add[u]) {
if(p[u].ls)add_tag(p[u].ls,add[u]);
if(p[u].rs)add_tag(p[u].rs,add[u]);
add[u]=0;
}
if(bo[u]) {
if(p[u].ls)solve(p[u].ls,cov[u],hiscov[u]);
if(p[u].rs)solve(p[u].rs,cov[u],hiscov[u]);
bo[u]=0;
}
} void change(int u) {
if(R<p[u].mn[0]||L>p[u].mx[1]) {cov_tag(u);return;}
if(L<=p[u].mn[1]&&p[u].mx[0]<=R) {add_tag(u,1);return;}
push_down(u);
if(p[u].c[1]<L||p[u].c[0]>R)cnt[u]=0;
else cnt[u]++,hismx[u]=max(hismx[u],cnt[u]);
if(p[u].ls)change(p[u].ls);
if(p[u].rs)change(p[u].rs);
} void make_ans(int u) {
ans[p[u].id]=hismx[u];
push_down(u);
if(p[u].ls)make_ans(p[u].ls);
if(p[u].rs)make_ans(p[u].rs);
}
} int main() {
n=read(),m=read();
for(int i=1;i<=n;i++)
a[i].l=read(),a[i].r=read();
T::prepare();
for(int i=1;i<=n;i++) {
L=a[i].l,R=a[i].r;
T::change(T::root);
}
T::make_ans(T::root);
for(int i=1;i<=m;i++)
printf("%d\n",ans[i]);
return 0;
}

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

  1. bzoj4130: [PA2011]Kangaroos

    Description 定义两个区间互相匹配表示这两个区间有交集. 给出长度为N的区间序列A,M次询问,每次询问序列A中最长的连续子序列,使得子序列中的每个区间都与[L,R]互相匹配 N<=50 ...

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

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

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

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

  4. bzoj AC倒序

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

  5. java web 开发三剑客 -------电子书

    Internet,人们通常称为因特网,是当今世界上覆盖面最大和应用最广泛的网络.根据英语构词法,Internet是Inter + net,Inter-作为前缀在英语中表示“在一起,交互”,由此可知In ...

  6. 所有selenium相关的库

    通过爬虫 获取 官方文档库 如果想获取 相应的库 修改对应配置即可 代码如下 from urllib.parse import urljoin import requests from lxml im ...

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

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

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

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

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

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

随机推荐

  1. freeswitch中集成使用ekho实现TTS功能一

    Linux下安装freeswitch并集成ekho实现TTS 1. linux下安装freeswitch就不多介绍了,具体链接网址: http://www.8000hz.com/archives/14 ...

  2. Android驱动开发全过程(有图有真相)

    转:https://wenku.baidu.com/view/349bd159b7360b4c2e3f64b1.html

  3. tcp/ip 中的分组和分片

    osi 大家应该都知道osi七层模型吧,物理层 链路层 网络层 传输层 会话层 表示层 应用层ip 属于网络层,tcp 属于传输层,你可以把每一层想像成粽子的粽叶,包裹了七层的粽子最外面的就是物理层, ...

  4. DNS 主从同步配置

    DNS 主从同步配置 主从同步:主每次修改配置文件需要修改一下序列号,主从同步主要 看序列号. 从DNS:从是可以单独修改,主从不会报错.但从修改后,主端同步给从后 从端修改数据会丢失 主从原理:从会 ...

  5. INSPIRED启示录 读书笔记 - 第29章 大公司如何创新

    大公司实现创新的方法 20%法则:谷歌的程序员有20%的工作时间可以用来从事创新研究,这个方法最早是从施乐帕克研究所学来的.20%法则鼓励普通员工自己尝试各种想法,让员工打心底愿意倾注更多的激情和汗水 ...

  6. 斯坦福机器学习视频笔记 Week8 无监督学习:聚类与数据降维 Clusting & Dimensionality Reduction

    监督学习算法需要标记的样本(x,y),但是无监督学习算法只需要input(x). 您将了解聚类 - 用于市场分割,文本摘要,以及许多其他应用程序. Principal Components Analy ...

  7. vector对象

    vector是模板而非类型,由vector生成的类型必须包含vector中元素的类型,例如vector<int> 定义和初始化vector对象: vector<T> v1    ...

  8. Linux 修改DNS解决 Could not retrieve mirrorlist" 报错

    CentOS yum有时出现“Could not retrieve mirrorlist ”的解决办法——resolv.conf的配置 或者IP配置文件上写入 缺少DNS引起的问题1. 无法识别域名 ...

  9. struts2中常用配置

    1.Post提交乱码问题,如果编码采用的是utf-8,那么默认不需要自己处理,因为其默认的常量配置文件就是处理UTF-8的 这个常量值只处理POST提交,get如果乱码还得自己写拦截器处理,一般只要页 ...

  10. MapReduce-从HBase读取数据处理后再写入HBase

    MapReduce-从HBase读取处理后再写入HBase 代码如下 package com.hbase.mapreduce; import java.io.IOException; import o ...