「luogu2569」[ZJOI2006] 书架
「luogu2569」[ZJOI2006]书架
题目大意
给定一个长度为 \(n\) 序列,序列中第 \(i\) 个元素有编号 \(a_i(a_i \in \Z \cap [1,n])\),需要支持五种操作:
- \(Top\) \(S\) ——表示把编号为 \(S\) 的书放在最上面;
- \(Bottom\) \(S\)——表示把编号为 \(S\) 的书放在最下面;
- \(Insert\) \(S\) \(T\)——\(T \in \{-1,0,1\}\),若编号为 \(S\) 的书上面有 \(X\) 本书,则这条命令表示把这本书放回去后它的上面有 \(X+T\) 本书;
- \(Ask\) \(S\)——询问编号为 \(S\) 的书的上面目前有多少本书;
- \(Query\) \(S\)——询问从上面数起的第 \(S\) 本书的编号。
对于每个 \(Ask\),\(Query\) 操作,输出答案。
(以上摘自luogu)
题解
\(fhq\_treap\) 复健,没有题解。
代码如下:
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cstdlib>
inline int in() {
int x=0;char c=getchar();bool f=false;
while(c<'0'||c>'9') f|=c=='-', c=getchar();
while(c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48), c=getchar();
return f?-x:x;
}
const int N = 8e4+5;
int mp[N];
struct fhq_treap {
#define t a[p]
#define lson a[a[p].l]
#define rson a[a[p].r]
struct node {
int l, r, key, size, fa, rnd;
}a[N];
int tot, rt;
inline int new_node(int key) {
a[++tot]=(node){0, 0, key, 1, 0, rand()};
mp[key]=tot;
return tot;
}
inline void push_up(int p) {
if(p) {
t.size=lson.size+rson.size+1;
lson.fa=rson.fa=p;
}
}
void split(int p, int &x, int &y, int k) {
if(!p) return (void)(x=y=0);
if(lson.size<k) x=p, split(t.r, t.r, y, k-lson.size-1);
else y=p, split(t.l, x, t.l, k);
push_up(p);
}
int merge(int x, int y) {
if(!x||!y) return x?x:y;
int p=0;
if(a[x].rnd<a[y].rnd) p=x, t.r=merge(t.r, y);
else p=y, t.l=merge(x, t.l);
push_up(p);
return p;
}
inline int kth_id(int k) {
int p=rt;
while(lson.size+1!=k)
if(lson.size>=k) p=t.l;
else k-=lson.size+1, p=t.r;
return a[p].key;
}
inline int find_rank(int p) {
int ret=lson.size+1;
for(;p!=rt;p=t.fa)
if(a[t.fa].r==p) ret+=a[a[t.fa].l].size+1;
return ret;
}
void debug(int p) {
if(t.l) debug(t.l);
printf(" %d", a[p].key);
if(t.r) debug(t.r);
}
#undef t
#undef lson
#undef rson
}T;
int main() {
srand(20021111);
char opt[10];
int n=in(), m=in();
for(int i=1;i<=n;++i) T.rt=T.merge(T.rt, T.new_node(in()));
int a, b, c, d, s, t, k;
while(m--) {
scanf("%s", opt), s=in();
if(opt[0]=='T') {
k=T.find_rank(mp[s]);
T.split(T.rt, a, b, k);
T.split(a, a, c, k-1);
T.rt=T.merge(T.merge(c, a), b);
}
else if(opt[0]=='B') {
k=T.find_rank(mp[s]);
T.split(T.rt, a, b, k);
T.split(a, a, c, k-1);
T.rt=T.merge(a, T.merge(b, c));
}
else if(opt[0]=='I') {
t=in();
k=T.find_rank(mp[s]);
if(t>0) {
T.split(T.rt, a, b, k);
T.split(a, a, c, k-1);
T.split(b, b, d, k-T.a[a].size-T.a[c].size+1);
T.rt=T.merge(T.merge(a, b), T.merge(c, d));
}
else if(t<0) {
T.split(T.rt, a, b, k-1);
T.split(a, a, c, k-2);
T.split(b, b, d, k-T.a[a].size-T.a[c].size);
T.rt=T.merge(T.merge(a, b), T.merge(c, d));
}
}
else if(opt[0]=='A') printf("%d\n", T.find_rank(mp[s])-1);
else printf("%d\n", T.kth_id(s));
//T.debug(T.rt);
//putchar('\n');
}
return 0;
}
「luogu2569」[ZJOI2006] 书架的更多相关文章
- 嘴巴题5 「BZOJ1864」[ZJOI2006] 三色二叉树
1864: [Zjoi2006]三色二叉树 Time Limit: 1 Sec Memory Limit: 64 MB Submit: 1195 Solved: 882 [Submit][Status ...
- 「bzoj1003」「ZJOI2006」物流运输 最短路+区间dp
「bzoj1003」「ZJOI2006」物流运输---------------------------------------------------------------------------- ...
- 「MoreThanJava」Java发展史及起航新世界
「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...
- 「译」JUnit 5 系列:条件测试
原文地址:http://blog.codefx.org/libraries/junit-5-conditions/ 原文日期:08, May, 2016 译文首发:Linesh 的博客:「译」JUni ...
- 「译」JUnit 5 系列:扩展模型(Extension Model)
原文地址:http://blog.codefx.org/design/architecture/junit-5-extension-model/ 原文日期:11, Apr, 2016 译文首发:Lin ...
- JavaScript OOP 之「创建对象」
工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程.工厂模式虽然解决了创建多个相似对象的问题,但却没有解决对象识别的问题. function createPers ...
- 「C++」理解智能指针
维基百科上面对于「智能指针」是这样描述的: 智能指针(英语:Smart pointer)是一种抽象的数据类型.在程序设计中,它通常是经由类型模板(class template)来实做,借由模板(tem ...
- 「JavaScript」四种跨域方式详解
超详细并且带 Demo 的 JavaScript 跨域指南来了! 本文基于你了解 JavaScript 的同源策略,并且了解使用跨域跨域的理由. 1. JSONP 首先要介绍的跨域方法必然是 JSON ...
- 「2014-5-31」Z-Stack - Modification of Zigbee Device Object for better network access management
写一份赏心悦目的工程文档,是很困难的事情.若想写得完善,不仅得用对工具(use the right tools),注重文笔,还得投入大把时间,真心是一件难度颇高的事情.但,若是真写好了,也是善莫大焉: ...
随机推荐
- zcu102 hdmi example(一)
1,概述 有一个计划是打算做一个摄像头的驱动与显示. 但是实际上手上只有一个zcu102开发板,没有摄像头,也没有上位机,自己也不会写.所以就将方案阉割成将录制好的视频放在SD卡里面,然后从SD卡里面 ...
- java+testng接口测试入门
testNG是一个测试框架,它能组织测试用例按照你想要的方式进行运行,并输出一定格式的便于阅读的测试报告(结果),通过java+testng的方式说明一下接口测试的基本使用方法. 一.环境搭建 a)千 ...
- PyQt5中的信号与槽,js 与 Qt 对象之间互相调用
一.PyQt中的信号与槽 信号(Signal)和槽(Slot)是Qt中的核心机制,用在对象之间互相通信.在Qt中每个QObject对象和PyQt中所有继承自QWidget的控件(这些都是QObject ...
- nginx基础之【study one】
Nginx是种代理服务器,即可以作为反向代理服务器.邮件服务器等HTTP服务器,支持很多第三方模块扩展,如GZip.SSL.FastCGI. 最常用的功能有Http反向代理.负载均衡和Web缓存: 1 ...
- css浮动学习
以前网页中的局都是使用浮动来实现的(毕竟ie9也不支持flex-box).而浮动在css中是一个挺难理解的概念,这次再巩固一下,float的具体使用事项. 1.行内元素和块元素的区别? 行内元素(im ...
- 4月23日 MySQL学习-DDL
今日学习的是DDL的操作(数据定义语言) create table teachers (id int,name varchar(50));//创建一个表 给了两个类型alter table stude ...
- MySQL数据库存储引擎
这里主要介绍最常用的两种存储引擎. 1.InnoDB InnoDB是一个事务型的存储引擎,有行级锁定和外键约束.Innodb引擎提供了对数据库ACID事务的支持,并且实现了SQL标准的四种隔离级别,关 ...
- Linux C Socket简单实例与详细注释
最近做的东西与socket十分紧密,所以很好奇它具体是如何实现的,以前也有了解过,但是又忘记了,于是把它记录下来,以便日后查看. 服务器端:server.c #include <sys/type ...
- linux makefile中一些复制运算的区别
Makefile 中 :=. ?= .+= .=的区别 = 是最基本的赋值:= 是覆盖之前的值?= 是如果没有被赋值过就赋予等号后面的值,如果已经被赋值则就用之前的赋值+= 是添加等号后面的值
- nginx配置反向代理CAS单点登录应用
新增如下配置即可: location /cas { proxy_pass http://172.16.20.155:8080/cas; proxy_redirect default; proxy_re ...