luogu P4848 崂山白花蛇草水
https://www.luogu.org/problemnew/show/P4848
我的数据结构大概已经废了。
外层权值线段树内层kdtree,外层线段树上二分答案。
码数据结构一时爽,码完debug火葬场。
要rebuild时少写了个else什么的
插入不upd下去的时候没把值更新完比如sz什么的
比较Int的时候把外层数组套多套少什么的
拿什么拯救你,我的数据结构
吸氧才能过的代码,据说没人能不吸氧过。
//Achen
#include<bits/stdc++.h>
#define For(i,a,b) for(int i=(a);i<=(b);i++)
#define Rep(i,a,b) for(int i=(a);i>=(b);i--)
#define Formylove return 0
const int N=100007,UP=1e9;
typedef long long LL;
typedef double db;
using namespace std;
int n,q,lastans;
int xl,yl,xr,yr,Qrs; template<typename T> void read(T &x) {
char ch=getchar(); x=0; T f=1;
while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
if(ch=='-') f=-1,ch=getchar();
for(;ch>='0'&&ch<='9';ch=getchar()) x=x*10+ch-'0'; x*=f;
} #define lc ch[x][0]
#define rc ch[x][1]
#define mid ((l+r)>>1) struct pt {
int d[2],v;
}p[N*33];
int rt[N*33],cnt,dt[N*33][2][2],ch[N*33][2],sz[N*33],f[N*33],D; void upd(int x) {
dt[x][0][0]=dt[x][0][1]=p[x].d[0];
dt[x][1][0]=dt[x][1][1]=p[x].d[1];
if(lc) {
dt[x][0][0]=min(dt[x][0][0],dt[lc][0][0]);
dt[x][0][1]=max(dt[x][0][1],dt[lc][0][1]);
dt[x][1][0]=min(dt[x][1][0],dt[lc][1][0]);
dt[x][1][1]=max(dt[x][1][1],dt[lc][1][1]);
}
if(rc) {
dt[x][0][0]=min(dt[x][0][0],dt[rc][0][0]);
dt[x][0][1]=max(dt[x][0][1],dt[rc][0][1]);
dt[x][1][0]=min(dt[x][1][0],dt[rc][1][0]);
dt[x][1][1]=max(dt[x][1][1],dt[rc][1][1]);
}
sz[x]=sz[lc]+sz[rc]+1;
} int sta[N],top;
void tra(int x) {
if(lc) tra(lc);
sta[++top]=x;
if(rc) tra(rc);
} bool cmp(const int &A,const int &B) { return p[A].d[D]<p[B].d[D]; } int build(int l,int r,int dd) {
D=dd;
if(l>r) return 0;
nth_element(sta+l,sta+mid,sta+r+1,cmp);
int x=sta[mid];
lc=build(l,mid-1,dd^1); if(lc) f[lc]=x;
rc=build(mid+1,r,dd^1); if(rc) f[rc]=x;
upd(x); return x;
} int rebuild(int x,int F,int dd) {
top=0; tra(x);
int rs=build(1,top,dd);
f[rs]=F; return rs;
} int bal(int x) { return sz[x]*0.85>=max(sz[lc],sz[rc]); } void insert(int &RT,pt A) {
int x=RT;
for(int fa=0,l=0,dd=0;;dd^=1) {
if(!x) {
x=++cnt; p[x]=A;
upd(x);
f[x]=fa;
if(fa) ch[fa][l]=x;
else RT=x;
break ;
}
dt[x][0][0]=min(dt[x][0][0],A.d[0]);
dt[x][0][1]=max(dt[x][0][1],A.d[0]);
dt[x][1][0]=min(dt[x][1][0],A.d[1]);
dt[x][1][1]=max(dt[x][1][1],A.d[1]); sz[x]++;
if(A.d[dd]<p[x].d[dd]) fa=x,x=lc,l=0;
else fa=x,x=rc,l=1;
}
int ls=-1,dd=0,lsd;
for(int tp=x;;tp=f[tp],dd^=1) {
if(!bal(tp)) ls=tp,lsd=dd;
if(tp==RT) break;
}
if(ls!=-1) {
if(ls==RT) RT=rebuild(ls,0,0);
else ch[f[ls]][ls==ch[f[ls]][1]]=rebuild(ls,f[ls],lsd^dd);
}
} void qry(int x) {
if(!x) return ;
if(dt[x][0][0]>xr||dt[x][0][1]<xl||dt[x][1][0]>yr||dt[x][1][1]<yl) return;
if(dt[x][0][0]>=xl&&dt[x][0][1]<=xr&&dt[x][1][0]>=yl&&dt[x][1][1]<=yr) {
Qrs+=sz[x]; return ;
}
if(p[x].d[0]>=xl&&p[x].d[0]<=xr&&p[x].d[1]>=yl&&p[x].d[1]<=yr) Qrs++;
if(lc) qry(lc); if(rc) qry(rc);
} int sgrt,tot,lson[N*33],rson[N*33];
void upd(int &x,int l,int r,int pos,pt A) {
if(!x) x=++tot; insert(rt[x],A);
if(l==r) return ;
if(pos<=mid) upd(lson[x],l,mid,pos,A);
else upd(rson[x],mid+1,r,pos,A);
} int qry(int x,int l,int r,int k) {
Qrs=0;
if(l==r) {
qry(rt[x]);
if(Qrs>=k) return l;
else return 0;
}
qry(rt[rson[x]]);
if(Qrs>=k) return qry(rson[x],mid+1,r,k);
else return qry(lson[x],l,mid,k-Qrs);
} int main() {
//freopen("4605.in","r",stdin);
//freopen("4605.out","w",stdout);
read(n); read(q);
For(i,1,q) {
int o;
read(o);
if(o==1) {
int x,y,v;
read(x); read(y); read(v);
x^=lastans; y^=lastans; v^=lastans;
upd(sgrt,1,UP,v,(pt){x,y,v});
}
else {
int k;
read(xl); read(yl); read(xr); read(yr);
xl^=lastans; yl^=lastans;
xr^=lastans; yr^=lastans;
read(k); k^=lastans;
lastans=qry(sgrt,1,UP,k);
if(!lastans) puts("NAIVE!ORZzyz.");
else printf("%d\n",lastans);
}
}
Formylove;
}
//Achen
#include<bits/stdc++.h>
#define For(i,a,b) for(int i=(a);i<=(b);i++)
#define Rep(i,a,b) for(int i=(a);i>=(b);i--)
#define Formylove return 0
const int N=;
typedef long long LL;
typedef double db;
using namespace std;
int a[N][N]; template<typename T> void read(T &x) {
char ch=getchar(); T f=; x=;
while(ch!='-'&&(ch<''||ch>'')) ch=getchar();
if(ch=='-') f=-,ch=getchar();
for(;ch>=''&&ch<='';ch=getchar()) x=x*+ch-''; x*=f;
} int main() {
//freopen("1.in","w",stdout);
srand(time());
int n=,m=rand()%+;
printf("%d %d\n",n,m);
For(i,,m) {
int o;
o=rand()%+;
//if(i<=m/2) o=1; else o=2;
if(i<=) {
int x=rand()%n+,y=rand()%n+,v=rand()%+;
printf("1 %d %d %d\n",x,y,v);
}
else {
int xl,yl,xr,yr,k;
xl=rand()%n+,xr=rand()%n+;
yl=rand()%n+,yr=rand()%n+;
if(xl>xr) swap(xl,xr);
if(yl>yr) swap(yl,yr);
k=rand()%n+;
printf("2 %d %d %d %d %d\n",xl,yl,xr,yr,k);
}
}
Formylove;
}
luogu P4848 崂山白花蛇草水的更多相关文章
- 洛谷P4848 崂山白花蛇草水 权值线段树+KDtree
题目描述 神犇 \(Aleph\) 在 \(SDOI\ Round2\) 前立了一个 \(flag\):如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇 \(Aleph\) 的实力,他轻松地进了山 ...
- P4848 崂山白花蛇草水
题意:支持修改的矩形第 \(k\) 大. 题解:动态开点权值线段树 套 Kd-tree. 然后也没什么难的但就是写不对...调了两天才调出来然后发现跑的巨慢,于是又%了一发Claris'题解,跑的真快 ...
- bzoj 4605: 崂山白花蛇草水
Description 神犇Aleph在SDOI Round2前立了一个flag:如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇Aleph的实 力,他轻松地进了山东省省队,现在便是他履行诺言的时 ...
- LG4848 崂山白花蛇草水
题意 神犇 Aleph 在 SDOI Round2 前立了一个 flag:如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇 Aleph 的实力,他轻松地进了山东省省队,现在便是他履行诺言的时候了. ...
- BZOJ4605:崂山白花蛇草水
浅谈\(K-D\) \(Tree\):https://www.cnblogs.com/AKMer/p/10387266.html 题目传送门:https://lydsy.com/JudgeOnline ...
- 【BZOJ4605】崂山白花蛇草水 权值线段树+kd-tree
[BZOJ4605]崂山白花蛇草水 Description 神犇Aleph在SDOI Round2前立了一个flag:如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇Aleph的实力,他轻松地进了 ...
- 【bzoj4605】崂山白花蛇草水 权值线段树套KD-tree
题目描述 神犇Aleph在SDOI Round2前立了一个flag:如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇Aleph的实力,他轻松地进了山东省省队,现在便是他履行诺言的时候了.蒟蒻Bob ...
- 崂山白花蛇草水 权值线段树套KDtree
Description 神犇Aleph在SDOI Round2前立了一个flag:如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇Aleph的实 力,他轻松地进了山东省省队,现在便是他履行诺言的时 ...
- bzoj4605: 崂山白花蛇草水 权值线段树套KDtree
bzoj4605: 崂山白花蛇草水 链接 bzoj loj 思路 强制在线,那就权值线段树套KDtree好了,没啥好讲的. KDtree要加平衡因子来重构.另外,那水真难喝. 错误 树套树一边写过了, ...
随机推荐
- 设计模式之单例模式--instance
<?php header('Content-Type:text/html;charest=utf-8'); /** * 设计模式之单例模式 * $_instance必须声明为静态的私有变量 * ...
- flex 实现图片播放 方案一 图片全部预加载放内存
这种方案,对于web的应用有局限性,在图片量比较多,比较大的时候,就会爆浏览器异常.一般建议轻量级的采用这种方案. <?xml version="1.0" encoding= ...
- IMX6Q RTC驱动分析
对于在工作中学习驱动的,讲究的是先使用,再理解.好吧,我们来看看板子里是如何注册的? 在板文件里,它的注册函数是这样的: imx6q_add_imx_snvs_rtc() 好吧,让我们追踪下去: 1 ...
- 数据库系统概论学习4-SQL 语句和关系代数(二)单表查询
4.12 字符匹配 精确查询和模糊查询 在这一节之前,我们学习的查询几乎都是精确查询,这就需要我们明确地知道某些属性的具体值.例如我们需要查询 'Wangxiaoxiao' 同学的信息,就需要在WHE ...
- Kubernetes client-go
Github地址:https://github.com/kubernetes/client-go 访问kubernetes集群有几下几种方式: 方式 特点 支持者 Kubernetes dashboa ...
- 【转载】有向图强连通分量的Tarjan算法
转载地址:https://www.byvoid.com/blog/scc-tarjan [有向图强连通分量] 在有向图G中,如果两个顶点间至少存在一条路径,称两个顶点强连通(strongly conn ...
- Windows系统 本地文件如何复制到远程服务器
很多人在使用远程服务器的时候往往要将本地的文件传输到远程服务器内,方法有很多种,下面介绍下如何使用Windows自带的远程桌面连接程序将文件复制到远程服务器内. 1.首先,点击windows开始按钮, ...
- 算法总结之 数组的partition调整 三个值的升序
给定一个数组arr, 其中只可能有 0,1,2三个值,请实现arr排序 另一种问法: 有一个数组,只有红 蓝 黄 球,请事先红球全放在数组的左边,蓝球放中间,黄球放右边 另一种问法: 有一个数组,再给 ...
- mysql中两表更新时产生的奇葩问题,产生死锁!
如下一个两表更新语句 UPDATE hzxm201610 a,xmhzylb1201610 b SET a.gk07_1_6=b.gk04_11,a.gk07_2_6=b.f06_1,a.gk07_3 ...
- 【bzoj5055】膜法师(离散化+树状数组)
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=5055 这道题……不得不说,从标题到题面都能看出一股浓浓的膜法气息……苟…… 题意就是统计顺序 ...