1861: [Zjoi2006]Book 书架

Time Limit: 4 Sec  Memory Limit: 64 MB
Submit: 1453  Solved: 822
[Submit][Status][Discuss]

Description

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

Input

第一行有两个数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

对于每一条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

2
9
9
7
5
3

HINT

数据范围

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

Source

Day2

————————————————————————

splay维护序列的裸题

只需要维护一个子树大小size

1.top 将一个点删除,插入到根节点最左儿子

2.bottom 将一个点删除,插入到根节点最右儿子

3.insert +1 -1 (记录s前一个点为prev,后一个点为next)

-1 prev提根,s插在prev和它的左儿子之间

+1 next提根,s插在next和它的右儿子之间

4.ask  s提根,左儿子的size

5.query 递归查找即可

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
#include <set>
#include <vector>
#include <string.h>
#define siji(i,x,y) for(int i=(x);i<=(y);++i)
#define gongzi(j,x,y) for(int j=(x);j>=(y);--j)
#define xiaosiji(i,x,y) for(int i=(x);i<(y);++i)
#define sigongzi(j,x,y) for(int j=(x);j>(y);--j)
#define inf 0x1f1f1f1f
#define ivorysi
#define mo 97797977
#define hash 974711
#define base 47
#define MAXN 100005
#define fi first
#define se second
#define pii pair<int,int>
using namespace std;
typedef long long ll;
struct node {
int size,son[],fa;
void clear() {
size=son[]=son[]=fa=;
}
}tree[MAXN];
int root;
//维护size
void update(int x,int c) {
int k=tree[x].size;
int o=tree[x].fa;
tree[x].size=tree[o].size;
tree[o].size=tree[o].size-k+tree[tree[x].son[c]].size;
}
void rotate(int x,int c) {
update(x,c);
int o=tree[x].fa;
if(tree[o].fa!=) {
int t= o==tree[tree[o].fa].son[] ? : ;
tree[tree[o].fa].son[t]=x;
}
tree[o].son[c^]=tree[x].son[c];
if(tree[o].son[c^])tree[tree[o].son[c^]].fa=o;
tree[x].son[c]=o;
tree[x].fa=tree[o].fa;
tree[o].fa=x; }
void splay(int x,int y) {
while(tree[x].fa!=y) {
int k1= x==tree[tree[x].fa].son[] ? : ;
int k2= tree[x].fa == tree[tree[tree[x].fa].fa].son[] ? : ;
if(tree[tree[x].fa].fa!=y && k2==k1) {
rotate(tree[x].fa,k1);
rotate(x,k1);
}
else {
rotate(x,k1);
}
}
if(y==) root=x;
else { }
}
int find(int x,int c) {
splay(x,);
int t=tree[x].son[c];
while(tree[t].son[c^]!=) {
t=tree[t].son[c^];
}
return t;
}
void delete_x(int prev,int next) {
if(prev!= && next!=) {
splay(prev,);
splay(next,prev);
tree[tree[root].son[]].son[]=;
--tree[tree[root].son[]].size;
}
else if(prev!=) {
splay(prev,);
tree[root].son[]=;
}
else {
splay(next,);
tree[root].son[]=;
}
--tree[root].size;
}
//0是top 1是bottom
void in_hurry(int x,int c) {
int pr=find(x,),ne=find(x,);
delete_x(pr,ne);
int t=root;
++tree[t].size;
tree[x].son[c^]=tree[t].son[c];
tree[tree[t].son[c]].fa=x;
tree[x].size=tree[tree[t].son[c]].size+;
tree[x].fa=t;
tree[t].son[c]=x;
}
int ask(int x) {
splay(x,);
return tree[tree[x].son[]].size;
}
void insert(int x,int c) {
if(c==) return;
if(ask(x)== && c==-) return;
int pr=find(x,),ne=find(x,);
delete_x(pr,ne);
int t= c==- ? pr : ne;
splay(t,);
c= c==- ? : ;
++tree[t].size;
tree[x].clear();
tree[x].son[c]=tree[t].son[c];
tree[tree[t].son[c]].fa=x;
tree[x].size=tree[tree[t].son[c]].size+;
tree[t].son[c]=x;
tree[x].fa=t;
splay(x,);
} void query(int x,int s) {
int temp=tree[tree[x].son[]].size+;
if(s==temp) {splay(x,);return;}
int t=s<temp ? : ;
s = s>=temp ? s-temp : s;
query(tree[x].son[t],s);
}
int n,m;
void init() {
scanf("%d%d",&n,&m);
int a=,b;
siji(i,,n) {
scanf("%d",&b);
tree[b].fa=a;
if(a!=) {
tree[a].son[]=b;
}
else {root=b;}
tree[b].size=n-i+;
a=b;
} }
void solve() {
init();
char ord[];
int s,t;
siji(i,,m) {
scanf("%s",ord);
if(ord[]=='T' || ord[]=='B' ) {
t=ord[]=='T' ? : ;
scanf("%d",&s);
in_hurry(s,t);
}
else if(ord[]=='I') {
scanf("%d%d",&s,&t);
insert(s,t);
}
else if(ord[]=='A'){
scanf("%d",&s);
printf("%d\n",ask(s));
}
else if(ord[]=='Q') {
scanf("%d",&s);
query(root,s);
printf("%d\n",root);
}
}
}
int main(int argc, char const *argv[])
{
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
solve();
}

BZOJ 1861: [Zjoi2006]Book 书架 (splay)的更多相关文章

  1. BZOJ 1861: [Zjoi2006]Book 书架 splay

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

  2. BZOJ 1861: [Zjoi2006]Book 书架 | SPlay 板题

    #include<cstdio> #include<algorithm> #include<cstring> #define N 80010 #define whi ...

  3. BZOJ 1861 [Zjoi2006]Book 书架 ——Splay

    [题目分析] 模板题目. 首尾两个虚拟结点,十分方便操作. [代码] #include <cstdio> #include <cstring> #include <cma ...

  4. BZOJ 1861: [Zjoi2006]Book 书架

    1861: [Zjoi2006]Book 书架 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 1290  Solved: 740[Submit][Stat ...

  5. bzoj1861 [Zjoi2006]Book 书架——splay

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1861 发现自己想splay的时候总是纠结那个点权是什么,因为splay原本是二分查找树... ...

  6. [bzoj 1861][zjoi2006] 书架

    传送门 Description 1. Top S--表示把编号为S的书放在最上面. 2. Bottom S--表示把编号为S的书放在最下面. 3. Insert S T--T∈{-1,0,1},若编号 ...

  7. bzoj1861 [Zjoi2006]Book 书架 splay

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

  8. [题解]bzoj 1861 Book 书架 - Splay

    1861: [Zjoi2006]Book 书架 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 1396  Solved: 803[Submit][Stat ...

  9. BZOJ-1861 Book 书架 Splay

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

随机推荐

  1. Hadoop基础-Hadoop快照管理

    Hadoop基础-Hadoop快照管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.快照的作用 快照可以迅速对文件(夹)进行备份,不产生新文件,使用差值存储,默认是禁用状态. ...

  2. nc命令的常用参数介绍

    nc命令的常用参数介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 想必做运维的应该在网络安全上都对一些开源软件都应该是相当的了解吧,比如tcpdump,namp等神奇,今天要给 ...

  3. 通过TodoList案例对比Vue.js的MVVM设计模式与JQuery的MVP设计模式

    Vue MVVM设计模式: 在使用vue进行编程时,不会再涉及到DOM的操作,取而代之的是修改数据层,当把数据进行变更的时候,vue之中它的底层会自动的根据数据的不同帮助我们去重新渲染页面. 编码时不 ...

  4. Java获取精确到秒的时间戳

    1.时间戳简介: 时间戳的定义:通常是一个字符序列,唯一地标识某一刻的时间.数字时间戳技术是数字签名技术一种变种的应用.是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01 ...

  5. MapReduce (hive表SequenceFile的结果做输入)、MultipleOutputs和Reduce端迭代iterable的一些说明

    很长时间以来一直写hive,嵌套脚本.偶尔写UDF.  最近用Hive的dynamic partition和多路插入做一些事情,很遗憾的结果是非常不稳定,有时能成功,有时失败.(可能是因为hive版本 ...

  6. jquery中美元符号命名冲突问题解决

    在Jquery中,$是JQuery的别名,所有使用$的地方也都可以使用JQuery来替换,如$('#msg')等同于JQuery('#msg') 的写法.然而,当我们引入多个js库后,在另外一个js库 ...

  7. Trying to get property of non-object

    原文:http://www.jb51.net/article/29878.htm 总结:判断为空用 if(isset($v)){}代替if($v == null){}

  8. CodeForces - 1040B Shashlik Cooking

    Long story short, shashlik is Miroslav's favorite food. Shashlik is prepared on several skewers simu ...

  9. 【leetcode 简单】 第九十七题 快乐数

    写一个程序,输出从 1 到 n 数字的字符串表示. 1. 如果 n 是3的倍数,输出“Fizz”: 2. 如果 n 是5的倍数,输出“Buzz”: 3.如果 n 同时是3和5的倍数,输出 “FizzB ...

  10. markdown小记(语法+markdownpad)

    一.有道云笔记markdown语法小记 1.目录[TOC] 2.标题# 一级标题## 二级标题...###### 六级标题 3.项目列表有序列表: 1. 1. (显示为i.) 2. 3. - (显示为 ...