bzoj1861 书架


原题链接


神题。。。

先吐槽洛谷的样例

10 10
1 3 2 7 5 8 10 4 9 6
Query 3
Top 5
Ask 6
Bottom 3
Ask 3
Top 6
Insert 4 –1
Query 5
Query 2
Ask 2

bzoj的样例

10 10
1 3 2 7 5 8 10 4 9 6
Query 3
Top 5
Ask 6
Bottom 3
Ask 3
Top 6
Insert 4 -1
Query 5
Query 2
Ask 2

区别?号与-号。。。

于是洛谷样例被我改了!!!


吐槽完毕

如果你知道书在哪这就是treap裸题。

然而不知道

所以,要知道书在哪。

可以一开始记录一下每个点的地址。

地址永远不会改变对吧

然后?一直跳father,如果他是father的rs就ans+=father的ls的size+1

ans初值为ls的size+1

为什么是对的?自己想

然而treap并不能维护father,只好加一个

updata时顺便更新

il vd reset(){
size=ls->size+rs->size+1;
if(ls!=null)ls->fa=this;if(rs!=null)rs->fa=this;
}

然后?treap裸题a

1A了

// It is made by XZZ
#include<cstdio>
#include<algorithm>
using namespace std;
#define rep(a,b,c) for(rg int a=b;a<=c;a++)
#define drep(a,b,c) for(rg int a=b;a>=c;a--)
#define erep(a,b) for(rg int a=fir[b];a;a=nxt[a])
#define il inline
#define rg register
#define vd void
#define mp make_pair
#define pr pair<point,point>
#define fir first
#define sec second
typedef long long ll;
il int gi(){
rg int x=0;rg char ch=getchar();
while(ch<'0'||ch>'9')ch=getchar();
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x;
}
const int maxn=80010;
int A[maxn],n;
int seed=233333;
il int Rand(){return seed=seed*23333ll%19260817;}
typedef struct node* point;
point null;
struct node{
int num,size,rand;
point ls,rs,fa;
node(int _num){num=_num,size=1,rand=Rand(),ls=rs=fa=null;}
il vd reset(){
size=ls->size+rs->size+1;
if(ls!=null)ls->fa=this;if(rs!=null)rs->fa=this;
}
};point root,pos[maxn];
il point build(int n){
point stk[n+1],now,lst;int top=0;
rep(i,1,n){
pos[A[i]]=now=new node(A[i]),lst=null;
while(top&&stk[top]->rand>now->rand)lst=stk[top],stk[top--]->reset();
if(top)stk[top]->rs=now;now->ls=lst,stk[++top]=now;
}
while(top)stk[top--]->reset();
return stk[1];
}
il point merge(point a,point b){
if(a==null)return b;
if(b==null)return a;
if(a->rand<b->rand){a->rs=merge(a->rs,b),a->reset();return a;}
b->ls=merge(a,b->ls),b->reset();return b;
}
il pr split(point x,int num){
if(x==null)return mp(null,null);
point ls=x->ls,rs=x->rs;
if(num==x->ls->size){x->ls=null,x->reset();return mp(ls,x);}
if(num==x->ls->size+1){x->rs=null,x->reset();return mp(x,rs);}
if(num<x->ls->size){pr t=split(x->ls,num);x->ls=t.sec;x->reset();return mp(t.fir,x);}
pr t=split(x->rs,num-x->ls->size-1);x->rs=t.fir;x->reset();return mp(x,t.sec);
}
il int getpos(point x){
int ret=x->ls->size+1;
while(x->fa!=null){
if(x==x->fa->rs)ret+=x->fa->ls->size+1;
x=x->fa;
}return ret;
}
int main(){
n=gi();
int m=gi();
null=new node(0);
null->size=0,null->ls=null->rs=null->fa=null;
rep(i,1,n)A[i]=gi();
root=build(n);
int S,T,p;
pr t1,t2,t3;point x;
char opt;
while(m--){
do opt=getchar();while(opt<'A'||opt>'Z');
if(opt=='T'){
S=gi(),p=getpos(pos[S]);
t1=split(root,p-1),t2=split(t1.sec,1);
root=merge(t2.fir,merge(t1.fir,t2.sec));
}
else if(opt=='B'){
S=gi(),p=getpos(pos[S]);
t1=split(root,p-1),t2=split(t1.sec,1);
root=merge(merge(t1.fir,t2.sec),t2.fir);
}
else if(opt=='I'){
S=gi(),scanf("%d",&T),p=getpos(pos[S]);
if(T==0)continue;
if(T==1)t1=split(root,p-1);else t1=split(root,p-2);
t2=split(t1.sec,1),t3=split(t2.sec,1);
root=merge(merge(merge(t1.fir,t3.fir),t2.fir),t3.sec);
}
else if(opt=='A')S=gi(),printf("%d\n",getpos(pos[S])-1);
else if(opt=='Q'){
p=gi();
t1=split(root,p-1);
x=t1.sec;while(x->ls!=null)x=x->ls;
printf("%d\n",x->num);
root=merge(t1.fir,t1.sec);
}
}
return 0;
}

bzoj1861 书架的更多相关文章

  1. bzoj1861 书架 splay版

    单点插入删除以及求前缀 #include<cstdio> #include<cstring> #include<algorithm> using namespace ...

  2. [BZOJ1861][Zjoi2006]Book 书架

    [BZOJ1861][Zjoi2006]Book 书架 试题描述 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候 ...

  3. [bzoj1861][Zjoi2006]Book 书架_非旋转Treap

    Book 书架 bzoj-1861 Zjoi-2006 题目大意:给你一个序列,支持:将指定编号的元素抽出,放到序列顶(底):将指定编号元素左右篡位:查询指定编号元素位置:查询指定数量位置元素编号. ...

  4. BZOJ-1861 Book 书架 Splay

    1861: [Zjoi2006]Book 书架 Time Limit: 4 Sec Memory Limit: 64 MB Submit: 1010 Solved: 588 [Submit][Stat ...

  5. BZOJ1861:[ZJOI2006]书架

    浅谈\(splay\):https://www.cnblogs.com/AKMer/p/9979592.html 浅谈\(fhq\)_\(treap\):https://www.cnblogs.com ...

  6. fhq_treap || BZOJ1861: [Zjoi2006]Book 书架 || Luogu P2596 [ZJOI2006]书架

    题面:P2596 [ZJOI2006]书架 题解:记录每本书对应的节点编号 普通fhq_treap无法查询一个权值的排名,所以在普通fhq_treap上多记录每个节点的父亲(可加在pushup函数中) ...

  7. BZOJ1861[ZJOI2006]Book书架

    Description 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书,看完后放回书柜然后再拿下 ...

  8. 【BZOJ1861】【splay】Book 书架

    Description 小 T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书,看完后放回书柜然后再拿 ...

  9. [BZOJ1861][ZJOI2006]书架

    BZOJ Luogu Description 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书,看 ...

随机推荐

  1. 8、RabbitMQ-消息的确认机制(生产者)

    RabbitMQ 之消息确认机制(事务+Confirm) https://blog.csdn.net/u013256816/article/details/55515234 概述: 在 Rabbitm ...

  2. HDU 1176 免费馅饼 (类似数字三角形的题,很经典,值得仔细理解的dp思维)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1176 免费馅饼 Time Limit: 2000/1000 MS (Java/Others)     ...

  3. VPP(Vector Packet Processing)配置工具

    前言 VPP提供了一个配置工具,让用户可以简单快捷地配置VPP.用户可以通过一些简单的命令配置VPP,功能包括安装及一些基本配置和测试用例. 使用 先安装一个python的pip模块,使用pip安装V ...

  4. C#中参数传递

    当调用带有参数的方法,需要向方法传递参数,有三种向方法传递参数的方式. 1.值参数:这种方式复制参数的实际值给形式参数,形参和实参使用的是内存中两个不相同的值,形参发生改变不会影响实参的值,从而保证了 ...

  5. Redhat7.2 ----team网卡绑定

    我先声明一下,team和bonding是一样的作用,只不过team多了几项功能bonding没有, 做team我们要最少准备两个网卡,我们这里主要显示主备模式. 首先我们先把网卡配置文件删除 nmcl ...

  6. 位图索引对于DML操作的影响

    位图索引相对于常规的B-tree 索引,有着体积更加小的优势,节省空间.对于重复率特别高的字段,比如性别,比如省份.查询效率要优于B-tree 索引.那为什么我们总被告知在业务库中不要使用呢? 业务库 ...

  7. WebGl 旋转(矩阵变换)

    代码1: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...

  8. js 实现内容的展开和收缩

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  9. 搭建kafka高级消费 (high-consumer)php7

    说明:有很多同学在服务器上搭建好,kafka,在应用端使用kafka时候出现很多问题,这里提供下我的kafka生产和消费的php函数 环境说明: 1:首先php要有kafka扩展,在命令行中输入 ph ...

  10. 基于 HTML5 Canvas 的 3D 渲染引擎构建生产管控系统

    前言 大家好,老郑我又回来了.这一期为大家带来一个非常好玩的 demo,我们制作一套自己的 3D 管道控制系统,运用了( http://www.hightopo.com )HT 的 Graph3dVi ...