「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),注重文笔,还得投入大把时间,真心是一件难度颇高的事情.但,若是真写好了,也是善莫大焉: ...
随机推荐
- kvm虚拟化介绍
一.虚拟化分类 1.虚拟化,是指通过虚拟化技术将一台计算机虚拟为多台逻辑计算机.在一台计算机上同时运行多个逻辑计算机,每个逻辑计算机可运行不同的操作系统,并且应用程序都可以在相互独立的空间内运行而互相 ...
- 算法笔记-exgcd
扩展欧几里得 扩展欧几里德算法是用来在已知a, b求解一组x,y, 使它们满足贝祖等式: ax+by = gcd(a, b) =d(解一定存在,根据数论中的相关定理). 扩展欧几里德常用在求解模线性方 ...
- 4月25日课上练习 一维数组最大子数组(debug版)
一维数组中求最大子数组的算法 package com.wangwang.mar; import java.util.Scanner; public class Sum { public static ...
- CentOS 安装 Ansible 以及连接Windows server的办法
1. CentOS机器上面按住那ansible yum install ansible 2. 安装 pywinrm 如果不安装 这个的话 ansible 会提示 没有 winrm 模块 注意需要先 ...
- docker 容器的启动方式
1.Docker 优势: .更高效利用系统资源:由于容器不需要进行硬件虚拟以及运行完整操作系统等额外开销,Docker 对系统资源的利用率更高.无论是应用执行速度.内存损耗或者文件存储速度,都要比传统 ...
- linux cp 直接覆盖不提示信息 解决方法
默认情况下,cp覆盖时,无论加什么参数 -f 之类的 还是提示是否覆盖. 原因是:服务器会默认增加别名 alias cp=’cp -i’,当你执行cp时,其实执行的是cp –i. [root@ltt0 ...
- STL用法整理
百度百科 STL是Standard Template Library的简称,中文名标准模板库,惠普实验室开发的一系列软件的统称.从根本上说,STL是一些“容器”的集合,这些“容器”有list,vect ...
- poj-1904(强连通缩点)
题意:有n个王子,每个王子都有k个喜欢的女生,王子挑选喜欢的女生匹配,然后再给你n个王子最开始就定好的匹配,每个王子输出能够结合且不影响其他王子的女生匹配 解题思路:强连通缩点,每个王子与其喜欢的女生 ...
- ubuntu下面配置apache
1.在这个目录下面修改这个文件 把那个注释了 2.在这个目录下面修改这个文件 把这个改为index的目录
- jmetter的http请求设置
1.设置 cookie 2.设置header 3.login 4.post请求 5.get请求