wikioi 1514 and ZJOI2006 书架

时间:2023-02-09 16:14:04

1514 书架

题目描述 Description

小 T有一个很大的书柜。这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列。她用 1 到 n 的正整数给每本书都编了号。 
    小 T 在看书的时候,每次取出一本书,看完后放回书柜然后再拿下一本。由于这些书太有吸引力了,所以她看完后常常会忘记原来是放在书柜的什么位置。不过小 T 的记忆力是非常好的,所以每次放书的时候至少能够将那本书放在拿出来时的位置附近,比如说她拿的时候这本书上面有 X 本书,那么放回去时这本书上面就只可能有 X-1、X或 X+1 本书。 
    当然也有特殊情况,比如在看书的时候突然电话响了或者有朋友来访。这时
候粗心的小 T 会随手把书放在书柜里所有书的最上面或者最下面,然后转身离
开。 
    久而久之,小 T 的书柜里的书的顺序就会越来越乱,找到特定的编号的书就变得越来越困难。于是她想请你帮她编写一个图书管理程序,处理她看书时的一些操作,以及回答她的两个提问:(1)编号为 X 的书在书柜的什么位置;(2)从上到下第 i 本书的编号是多少。

输入描述 Input Description

第一行有两个数 n,m,分别表示书的个数以及命令的条数;第二行为 n 个正整数:第i个数表示初始时从上至下第i个位置放置的书的编号;第三行到m+2行,每行一条命令。命令有 5 种形式: 
1. Top S——表示把编号为S的书房在最上面。 
2. Bottom S——表示把编号为 S的书房在最下面。 
3. Insert S T——T∈{-1,0,1},若编号为S的书上面有 X本书,则这条命令表示把这本书放回去后它的上面有X+T本书; 
4. Ask S——询问编号为S的书的上面目前有多少本书。 
5. Query S——询问从上面数起的第S本书的编号。

输出描述 Output Description

对于每一条 Ask 或 Query 语句你应该输出一行,一个数,代表询问的答案。

样例输入 Sample Input

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

样例输出 Sample Output






3

数据范围及提示 Data Size & Hint

30%的数据,n,m<=10000 
      100%的数据,n,m<=80000

题解:

神奇的splay!

我觉得刚开始的时候以序号按BST建树,

建好树之后在删除、加入的时候只是人为定义它的位置或者rank,

它的编号已经不代表什么了,而它的编号因为一直不变所以可以为我们做一些事情,比如本题

因此splay也可以回收废节点

。。。语言表达能力有限。。。

哪里说得不对请神牛指出

代码:

 const maxn=+;inf=maxlongint>>;
var i,n,m,x,t,rt:longint;
ch:char;
s,pos,v,fa,a:array[..maxn] of longint;
c:array[..maxn,..] of longint;
procedure pushup(x:longint);
begin
s[x]:=s[c[x,]]+s[c[x,]]+;
end;
procedure rotate(x:longint;var k:longint);
var l,r,y,z:longint;
begin
y:=fa[x];z:=fa[y];
l:=ord(c[y,]=x);r:=l xor ;
if y=k then k:=x else c[z,ord(c[z,]=y)]:=x;
fa[x]:=z;fa[y]:=x;fa[c[x,r]]:=y;
c[y,l]:=c[x,r];c[x,r]:=y;
pushup(y);pushup(x);
end;
procedure splay(x:longint;var k:longint);
var y,z:longint;
begin
while x<>k do
begin
y:=fa[x];z:=fa[y];
if y<>k then
if (c[z,]=y) xor (c[y,]=x) then rotate(x,k)
else rotate(y,k);
rotate(x,k);
end;
end;
function find(x,rank:longint):longint;
var l,r:longint;
begin
l:=c[x,];r:=c[x,];
if s[l]+=rank then exit(x)
else if s[l]>=rank then exit(find(l,rank))
else exit(find(r,rank-s[l]-));
end;
procedure del(k:longint);
var x,y,z:longint;
begin
x:=find(rt,k-);y:=find(rt,k+);
splay(x,rt);splay(y,c[x,]);
z:=c[y,];fa[z]:=;s[z]:=;c[y,]:=;
pushup(y);pushup(x);
end; procedure build(l,r,f:longint);
var mid,now,last:longint;
begin
if l>r then exit;
mid:=(l+r)>>;
now:=mid;last:=f;
fa[now]:=last;v[now]:=a[mid];
c[last,ord(mid>f)]:=now;
if l=r then
begin
s[now]:=;
exit;
end;
build(l,mid-,mid);build(mid+,r,mid);
pushup(now);
end; procedure init;
begin
readln(n,m);
for i:= to n+ do read(a[i]);readln;
for i:= to n+ do pos[a[i]]:=i;
build(,n+,);rt:=(n+)>>;
end;
procedure move(k,val:longint);
var x,y,z,rank:longint;
begin
if val= then exit;
z:=pos[k];splay(z,rt);rank:=s[c[z,]]+;del(rank);
if val=inf then begin x:=find(rt,n);y:=find(rt,n+);end
else if val=-inf then begin x:=find(rt,);y:=find(rt,);end
else begin x:=find(rt,rank+val-);y:=find(rt,rank+val);end;
splay(x,rt);splay(y,c[x,]);
fa[z]:=y;s[z]:=;c[y,]:=z;
pushup(y);pushup(x);
end;
procedure main;
begin
for i:= to m do
begin
read(ch);
case ch of
'T':begin
while ch<>' ' do read(ch);
readln(x);move(x,-inf);
end;
'B':begin
while ch<>' ' do read(ch);
readln(x);move(x,inf);
end;
'I':begin
while ch<>' ' do read(ch);
readln(x,t);move(x,t);
end;
'A':begin
while ch<>' ' do read(ch);
readln(x);
splay(pos[x],rt);writeln(s[c[rt,]]-);
end;
'Q':begin
while ch<>' ' do read(ch);
readln(x);
writeln(v[find(rt,x+)]);
end;
end;
end;
end;
begin
assign(input,'input.txt');assign(output,'output.txt');
reset(input);rewrite(output);
init;
main;
close(input);close(output);
end.

wikioi 1514 and ZJOI2006 书架的更多相关文章

  1. 「luogu2569」&lbrack;ZJOI2006&rsqb; 书架

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

  2. 洛谷 P2596 &lbrack;ZJOI2006&rsqb;书架 解题报告

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

  3. P2596 &lbrack;ZJOI2006&rsqb;书架 &amp&semi;&amp&semi; Splay 区间操作(三)

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

  4. &lbrack;Luogu 2596&rsqb; ZJOI2006 书架

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

  5. fhq&lowbar;treap &vert;&vert; BZOJ1861&colon; &lbrack;Zjoi2006&rsqb;Book 书架 &vert;&vert; Luogu P2596 &lbrack;ZJOI2006&rsqb;书架

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

  6. &lbrack;ZJOI2006&rsqb;书架(权值splay)

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

  7. &lbrack;洛谷P2596&rsqb; &lbrack;ZJOI2006&rsqb;书架

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

  8. BZOJ1861:&lbrack;ZJOI2006&rsqb;书架

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

  9. luogu2596 &lbrack;ZJOI2006&rsqb;书架

    treap.树是以"优先级"(优先级越小,在书架上越靠上)形成的,堆是以rand()的权值形成的.还要再维护一个原编号. 置顶/置底:找到那个元素,把它拉出来修改优先级再塞回去. ...

随机推荐

  1. &lbrack;APUE&rsqb;标准IO库&lpar;上&rpar;

    一.流和FILE对象 系统IO都是针对文件描述符,当打开一个文件时,即返回一个文件描述符,然后用该文件描述符来进行下面的操作,而对于标准IO库,它们的操作则是围绕流(stream)进行的. 当打开一个 ...

  2. vpsmate安装

    安装需求 操作系统:CentOS/Redhat 5.4 或 5.4 以上版本,32位或64位均可,推荐使用 CentOS 6.2 64位. 内存大小:运行时占用约 20MB 左右的服务器内存. 请使用 ...

  3. jQuery判断一个字符串中是否包含一个字符串(一)

    var key = 'java'; var str = "hello,javascript,welcome to my world"; if(key.indexOf(str)!=- ...

  4. 修改linux用户密码

    对于初学者来说,如何修改linux用户密码也不是件容易的事,其实非常简单,下面举例说明: 如果是以root身份登录,修改root密码.只要输入 passwd 就会出现: New password:  ...

  5. Extjs3 Combo实现百度搜索查询

    在Extjs中实现Combo手输模糊筛选出下拉框数据.之前一直利用的Combo的keyup来实时的请求数据库进行查询.最近发现了一个更好的方式:只需要引用一个ComboBoxQuery Ext.ns( ...

  6. Storm系列&lpar;四&rpar;Topology提交校验过程

    功能:提交一个新的Topology,并为Topology创建storm-id(topology-id),校验其结构,设置必要的元数据,最后为Topology分配任务. 实现源码: 1  ); Conf ...

  7. Kafka系列&lpar;二&rpar;特性和常用命令

    Kafka中Replicas复制备份机制 kafka将每个partition数据复制到多个server上,任何一个partition有一个leader和多个follower(可以没有),备份的个数可以 ...

  8. 网络流(最大流) CodeForces 546E:Soldier and Traveling

    In the country there are n cities and m bidirectional roads between them. Each city has an army. Arm ...

  9. ASCII码表及键盘码表。

             ASCII码表 ASCII值 控制字符 ASCII值 控制字符 ASCII值 控制字符 ASCII值 控制字符 0 NUT 32 (space) 64 @ 96 . 1 SOH 33 ...

  10. IT见解

    IT见解 北京海淀区  2014-10-18   张俊浩 *域名的市值在走低,因其功能被新浪.腾讯微博.微信大V这种账号所代替 *小米将自己定位为互联网公司,而不是手机公司 *手机不远的未来会成为公共 ...