bzoj 4605: 崂山白花蛇草水
Description
Input
Output
Sample Input
1 1 1 1
1 2 2 3
1 4 1 2
1 3 4 4
2 1 1 4 1 3
2 2 2 3 5 4
2 2 1 4 4 2
Sample Output
NAIVE!ORZzyz.
3
#include<cstdio>
#include<algorithm>
#define MN 1400010
#define M 2000
using namespace std; int n,m,X,ro[MN],L[MN],R[MN],x,y,num=,nm=,x1,x2,y1,y2,root=,xx,o,MMH=,mmh[MN],st[MN],l,r;
struct tr{
int x,y;
friend bool operator<(tr a,tr b){
if (X) return a.x<b.x;else return a.y<b.y;
}
}a[MN],A[MN];
struct tree{
int xa,xi,ya,yi,l,r,si;
}t[MN],T[MN];
char cs;
inline int read(){
cs=getchar();xx=;
while(cs<''||cs>'') cs=getchar();
while(cs>=''&&cs<='') xx=xx*+cs-,cs=getchar();
return xx;
}
inline void in(int &p,bool b){
if (!p){
p=num;
t[p].l=t[p].r=;
t[p].xa=t[p].xi=a[num].x;
t[p].ya=t[p].yi=a[num].y;
t[p].si=;
return;
}
X=b;t[p].si++;
if (a[num]<a[p]) in(t[p].l,b^);else in(t[p].r,b^);
t[p].xa=max(t[p].xa,a[num].x);
t[p].xi=min(t[p].xi,a[num].x);
t[p].ya=max(t[p].ya,a[num].y);
t[p].yi=min(t[p].yi,a[num].y);
}
inline int build(int l,int r,int now){
X=now;
int mid=(l+r)>>;
nth_element(A+l,A+mid,A+r+);
T[mid].si=r-l+;
T[mid].xa=T[mid].xi=A[mid].x;
T[mid].ya=T[mid].yi=A[mid].y;
if (l<mid) T[mid].l=build(l,mid-,now^),
T[mid].xa=max(T[T[mid].l].xa,T[mid].xa),
T[mid].xi=min(T[T[mid].l].xi,T[mid].xi),
T[mid].ya=max(T[T[mid].l].ya,T[mid].ya),
T[mid].yi=min(T[T[mid].l].yi,T[mid].yi);else T[mid].l=;
if (mid<r) T[mid].r=build(mid+,r,now^),
T[mid].xa=max(T[T[mid].r].xa,T[mid].xa),
T[mid].xi=min(T[T[mid].r].xi,T[mid].xi),
T[mid].ya=max(T[T[mid].r].ya,T[mid].ya),
T[mid].yi=min(T[T[mid].r].yi,T[mid].yi);else T[mid].r=;
return mid;
}
inline int wout(int p){
st[l=r=]=p;
while(l<=r){
A[l]=a[st[l]];
if (t[st[l]].l) st[++r]=t[st[l]].l;
if (t[st[l]].r) st[++r]=t[st[l]].r;
l++;
}
l=build(,r,);
for (register int i=;i<=r;i++) t[st[i]]=T[i],a[st[i]]=A[i],t[st[i]].l=st[t[st[i]].l],t[st[i]].r=st[t[st[i]].r];
return st[l];
return p;
}
inline void insert(int &p,int l,int r,int v,bool b){
if (!p) p=++nm,mmh[p]=M;
if (b){
a[++num].x=x;a[num].y=y;in(ro[p],);
if (t[ro[p]].si==mmh[p]) mmh[p]+=M,ro[p]=wout(ro[p]);
}
if (l==r) return;
int mid=l+r>>;
if (v<=mid) insert(L[p],l,mid,v,);else insert(R[p],mid+,r,v,);
}
inline int ask(int p){
if (t[p].xa<=x2&&t[p].xi>=x1&&t[p].ya<=y2&&t[p].yi>=y1) return ;
if (t[p].xi>x2||t[p].xa<x1||t[p].yi>y2||t[p].ya<y1) return ;
return ;
}
inline bool inl(int p){
if (a[p].x>=x1&&a[p].x<=x2&&a[p].y>=y1&&a[p].y<=y2) return ;
return ;
}
inline int QUE(int p){
int mmh=ask(p);
if (!mmh) return ;
if (mmh==) return t[p].si;else{
if (inl(p)) mmh=;else mmh=;
if (t[p].l) mmh+=QUE(t[p].l);
if (t[p].r) mmh+=QUE(t[p].r);
}
return mmh;
}
inline int que(int p,int l,int r,int k){
if (l==r) return l;
int u=;if (R[p]) u=QUE(ro[R[p]]);
int mid=l+r>>;
if (u<k) return que(L[p],l,mid,k-u);else return que(R[p],mid+,r,k);
}
int main(){
register int i,k;
n=read();m=read();
for (i=;i<=m;i++){
o=read();
if (o==) x=MMH^read(),y=MMH^read(),insert(root,,1e9,MMH^read(),);else{
x1=MMH^read();y1=MMH^read();x2=MMH^read();y2=MMH^read();k=MMH^read();
if (QUE(ro[root])<k) printf("NAIVE!ORZzyz.\n",MMH=);else
printf("%d\n",MMH=que(root,,1e9,k));
}
}
}
126604 kb 24240 ms C++/Edit 3738 B
bzoj 4605: 崂山白花蛇草水的更多相关文章
- BZOJ 4605 崂山白花蛇草水(权值线段树+KD树)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4605 [题目大意] 操作 1 x y k 表示在点(x,y)上放置k个物品, 操作 2 ...
- BZOJ4605:崂山白花蛇草水
浅谈\(K-D\) \(Tree\):https://www.cnblogs.com/AKMer/p/10387266.html 题目传送门:https://lydsy.com/JudgeOnline ...
- bzoj4605: 崂山白花蛇草水 权值线段树套KDtree
bzoj4605: 崂山白花蛇草水 链接 bzoj loj 思路 强制在线,那就权值线段树套KDtree好了,没啥好讲的. KDtree要加平衡因子来重构.另外,那水真难喝. 错误 树套树一边写过了, ...
- LG4848 崂山白花蛇草水
题意 神犇 Aleph 在 SDOI Round2 前立了一个 flag:如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇 Aleph 的实力,他轻松地进了山东省省队,现在便是他履行诺言的时候了. ...
- 【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的实 力,他轻松地进了山东省省队,现在便是他履行诺言的时 ...
- 洛谷P4848 崂山白花蛇草水 权值线段树+KDtree
题目描述 神犇 \(Aleph\) 在 \(SDOI\ Round2\) 前立了一个 \(flag\):如果进了省队,就现场直播喝崂山白花蛇草水.凭借着神犇 \(Aleph\) 的实力,他轻松地进了山 ...
- 【BZOJ 4605】崂山白花蛇草水 替罪羊树套线段树
外层是借鉴了kd-tree的替罪羊里层是线段树,插入就是正常插入+拍扁重建,查询的时候,我们就像树状数组套线段树一样操作在替罪羊中找到的线段树根节点,但是对于在kd-tree查找过程中遇到的单点,我们 ...
随机推荐
- 【java】java.util.Arrays类常用方法
package Arrays类; import java.util.Arrays; public class TestArrays { public static void main(String[] ...
- [置顶]
xamarin android 布局尺寸了解
为了使UI界面在不同大小的移动端显示器上能够正常显示,大家可能都知道使用sp作为字体大小的单位,dp作为其他元素长度的单位. 前几天看了一篇文章关于 App设计规范的,文章用心写的非常好,这里是链接 ...
- ArcGIS API for JavaScript 4.2学习笔记[17] 官方第七章Searching(空间查询)概览与解释
空间分析和空间查询是WebGIS有别于其他Web平台的特点.到这一章,就开始步入空间分析的内容了. [Search widget] 介绍空间查询的核心小部件"Search". [S ...
- 关于html,css,js三者的加载顺序问题
<head lang="en"> <meta charset="utf-8"> <title></title> ...
- 尤克里里 ukulele 单板 非kaka tom uma
本店冲人气优惠,不搞倒闭之类的事 23寸尤克里里 单板 单板 单板 彩贝镶边演出大气 单板 单板 单板 彩贝镶边演出大气 单板 单板 单板 彩贝镶边演出大气 配件选购40元全套(加棉琴包.金属变调夹. ...
- Head First设计模式之迭代器模式
一.定义 提供一种方法顺序访问一个聚合对象中各个元素, 而又无须暴露该对象的内部表示: 主要解决:不同的方式来遍历整个整合对象. 何时使用:遍历一个聚合对象. 如何解决:把在元素之间游走的责任交给迭代 ...
- linux ext4无法使用超过16T磁盘的解决办法
大磁盘使用问题 问题:当所要挂载的设备大于16T的时候,可以用parted正常分区,但是分区完成之后,无法格式化, 报错:Size of device /dev/sdb1 too big to be ...
- Python中将函数作为另一个函数的参数传入并调用
在Python中,函数本身也是对象,所以可以将函数作为参数传入另一函数并进行调用 在旧版本中,可以使用apply(function, *args, **kwargs)进行调用,但是在新版本中已经移除, ...
- Java的注释和Javadoc在eclipse生成的方法 – Break易站
本文内容来自:Java的注释和Javadoc在eclipse生成的方法 – Break易站 1. Java的注释 Java里有两种注释风格.下面这个写法是非常常见的 1 2 3 4 /*This i ...
- 横向、纵向时间轴timeline系列
近期移动端项目用到了很多时间轴.纵向的.开始可以实现,但是不利于维护.整理下, 以作为备份留存学习参考.子元素的 标签的 :before实现圆点,:after实现边线border纵向时间轴,单一右边内 ...