思路

一开始写fhq-treap

感觉越写越感觉splay好些,就去splay

然后维护序列

注意前驱后继的不存在的情况

但不用插入虚拟节点(那插入岂不太麻烦)

跑的真慢的一批,splay太多了

错误

好多错误

只好对拍

代码

//这个题用treap似乎小题大做了,所以我用splay
#include <iostream>
#include <cstdio>
#define FOR(i,a,b) for(int i=a;i<=b;++i)
using namespace std;
const int maxn=2e5+7;
int read() {
int x=0,f=1;char s=getchar();
for(;s>'9'||s<'0';s=getchar()) if(s=='-') f=-1;
for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
return x*f;
}
int n,m,a[maxn],rt,cnt,pos[maxn];
struct node {
int ch[2],fa,val,siz;
}e[maxn];
void pushup(int x) {
e[x].siz=e[e[x].ch[1]].siz+e[e[x].ch[0]].siz+1;
}
void rotate(int x) {
int y=e[x].fa,z=e[y].fa,k=(e[y].ch[1]==x);
e[z].ch[e[z].ch[1]==y]=x;
e[x].fa=z;
e[y].ch[k]=e[x].ch[k^1];
e[e[x].ch[k^1]].fa=y;
e[y].fa=x;
e[x].ch[k^1]=y;
pushup(x),pushup(y);
}
void splay(int x,int goal) {
while(e[x].fa!=goal) {
int y=e[x].fa,z=e[y].fa;
if(z!=goal) (e[y].ch[0]==x)^(e[z].ch[0]==y) ? rotate(x):rotate(y);
rotate(x);
}
if(goal==0) rt=x;
}
int k_th(int k) {
int now=rt;
while(233) {
if(e[e[now].ch[0]].siz+1==k) return e[now].val;
if(e[e[now].ch[0]].siz>=k) now=e[now].ch[0];
else k-=e[e[now].ch[0]].siz+1,now=e[now].ch[1];
}
splay(now,0);
}
int build(int l,int r,int f) {
if(l>r) return 0;
int mid=(l+r)>>1,p=(++cnt);
e[p].fa=f;
e[p].siz=1;
e[p].val=a[mid];
pos[a[mid]]=cnt;
e[p].ch[0]=build(l,mid-1,p);
e[p].ch[1]=build(mid+1,r,p);
pushup(p);
return p;
}
void dfs(int now) {
if(!now) return;
dfs(e[now].ch[0]);
cout<<e[now].val<<" ";
dfs(e[now].ch[1]);
}
int qq(int x) {
splay(x,0);
if(e[rt].val<e[x].val) return rt;
int now=e[rt].ch[0];
if(!now) return 0;
while(e[now].ch[1]) now=e[now].ch[1];
splay(now,0);
return now;
}
int hj(int x) {//x是pos
splay(x,0);
if(e[rt].val>e[x].val) return rt;
int now=e[rt].ch[1];
if(!now) return 0;
while(e[now].ch[0]) now=e[now].ch[0];
splay(now,0);
return now;
}
int p;
void delet(int x) {
int last=qq(x),nxt=hj(x);
if(last) splay(last,0);
if(nxt) splay(nxt,last);
if(nxt==0) {
p=e[last].ch[1];
e[last].ch[1]=0;
} else {
p=e[nxt].ch[0];
e[nxt].ch[0]=0;
if(nxt) splay(nxt,0);
}
}
void insert(int k) {
int now=rt;
while(e[now].ch[k]) now=e[now].ch[k];
e[now].ch[k]=p;
e[p].siz=1;
e[p].fa=now;
splay(p,0);
}
int main() {
n=read(),m=read();
FOR(i,1,n) a[i]=read();
rt=build(1,n,0);
char s[20];
FOR(i,1,m) {
cin>>s;
if(s[0]=='T') {
int a=read();
delet(pos[a]);
insert(0);
} else
if(s[0]=='B') {
int a=read();
delet(pos[a]);
insert(1);
} else
if(s[0]=='I') {
int a=read(),k=read(),b;
if(k==0) continue;
if(k==-1) b=qq(pos[a]);
else b=hj(pos[a]);
if(!b) continue;
int x=a,y=e[b].val;
swap(pos[x],pos[y]);
swap(e[pos[x]].val,e[pos[y]].val);
} else
if(s[0]=='A') {
int a=read();
splay(pos[a],0);
cout<<e[e[rt].ch[0]].siz<<"\n";
} else
if(s[0]=='Q') {
int a=read();
cout<<k_th(a)<<"\n";
}
}
return 0;
}

P2596 [ZJOI2006]书架的更多相关文章

  1. 洛谷 P2596 [ZJOI2006]书架 解题报告

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

  2. P2596 [ZJOI2006]书架 && Splay 区间操作(三)

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

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

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

  4. [洛谷P2596] [ZJOI2006]书架

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

  5. P2596 [ZJOI2006]书架(splay)

    [题目链接] https://www.luogu.org/problemnew/show/P2596 平衡树,需支持五个操作: 1. 将某元素置顶:将元素旋到根,然后将左子树合并到该元素的后继 2. ...

  6. luogu P2596 [ZJOI2006]书架

    传送门 感觉要死在\(Splay\)里了 orz 这题用\(Splay\)维护这个序列,其中的第\(k\)大点代表这个序列的第\(k\)个数 第一个操作,先把那个数所在的点旋到根,然后把整个根的左子树 ...

  7. 洛谷 P2596 [ZJOI2006]书架 (splay)

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

  8. 「luogu2569」[ZJOI2006] 书架

    「luogu2569」[ZJOI2006]书架 题目大意 给定一个长度为 \(n\) 序列,序列中第 \(i\) 个元素有编号 \(a_i(a_i \in \Z \cap [1,n])\),需要支持五 ...

  9. [Luogu 2596] ZJOI2006 书架

    [Luogu 2596] ZJOI2006 书架 第一次指针写 FHQ_Treap(省选噩梦数据结构)AC 啦! 省选试机写它,紧张过度失败了. 省选 Day 1 考场写它,写挂了. 省选 Day 1 ...

随机推荐

  1. javaweb + tomcat + 部署 + 域名绑定 + 默认首页

    ①:把javaweb项目打包成war(不会的自行百度) ②:把war拷贝到服务器的tomcat里面的webapps下 ③:到bin文件夹下.bat文件启动tomcat,启动后会解压war包 ⑤:解压后 ...

  2. PDO数据访问抽象层(下)

    PDO两大功能 一.事务功能 PDO的事务功能主要控制好几条sql语句同时成功或者同时失败(当其中一条SQL语句有错误时,同时好几条一起失败),失败时可以回滚操作 1.造对象 <?php $ds ...

  3. linux中截取文件的特定字节(去掉utf-8 bom头)

    事出有因,之所以要截取特定字节,是为了给utf-8编码的文件去掉bom头. bom头好去啊,notepad++文本编辑器中就有这个功能啊.可是,问题所在是要编辑的文件太大了,300MB,小电脑卡shi ...

  4. Python二分法查找

    1.1二分前提是有序,,否则不可以2分,2分查找的时间复杂度是O(log n):排序后二分查找到适当的位置插入数值 lst = [37,99,73,48,47,40,40,25,99,51] def ...

  5. linux整理

    文件查看命令 cat [OPTION]... [FILE]...  - E: 显示行结束符$ -n: 对显示出的每一行进行编号 -A:显示所有控制符 -b:非空行编号 -s:压缩连续的空行成一行 he ...

  6. ASP.NET MVC Action返回结果类型【转】

    ASP.NET MVC 目前一共提供了以下几种Action返回结果类型: 1.ActionResult(base) 2.ContentResult 3.EmptyResult 4.HttpUnauth ...

  7. Vue系列之 => 组件中的data和methods

    使用data <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  8. 城市里的间谍B901

    城市里的间谍   城市里的间谍 难度级别:C: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 某城市的地铁是线性的,有 n(2 <= n ...

  9. arm cortex-m0plus源码学习(二)AMBA3.0_ AHBLite

    1. AMBA总线概述 AMBA2.0 以上版本都是基于单沿时钟.单向信号线的协议[1]. 现在市场上大部分的基于 AMBA 架构的 SoC 产品, 系统总线采用 AHB, 外部总线采用 APB.系统 ...

  10. python XML文件解析:用xml.dom.minidom来解析xml文件

    python解析XML常见的有三种方法: 一是xml.dom.*模块,是W3C DOM API的实现,若需要处理DOM API则该模块很合适, 二是xml.sax.*模块,它是SAX API的实现,这 ...