[Luogu 2596] ZJOI2006 书架
[Luogu 2596] ZJOI2006 书架
第一次指针写 FHQ_Treap(省选噩梦数据结构)AC 啦!
省选试机写它,紧张过度失败了。
省选 Day 1 考场写它,写挂了。
省选 Day 1 当晚认真复习它,结果 Day 2 并不考。
于是省选后用指针写出来了,开心qwq。
这个题嘛,记录一下每个点对应的指针,顺便维护一下父节点,每次需要的时候,就可以一路向上找到这个点的位置。
就这么简单的呀qwq
#include <cstdio>
#include <cstdlib>
#include <ctime>
#include <stack>
using std::stack;
const int MAXN=80010;
int n,m,pos[MAXN];
class FHQ_Treap
{
public:
FHQ_Treap(void)
{
srand(19260817);
rt=nullptr;
}
~FHQ_Treap(void)
{
delete rt;
}
void Init(void)
{
Build(rt);
}
void Top(void)
{
int x;
Node *l,*r,*t;
scanf("%d",&x);
x=Rank(pos[x]);
Split(rt,x-1,l,r),Split(r,1,t,r),Merge(l,t,l),Merge(rt,l,r);
}
void Bottom(void)
{
int x;
Node *l,*r,*t;
scanf("%d",&x);
x=Rank(pos[x]);
Split(rt,x-1,l,r),Split(r,1,t,r),Merge(r,r,t),Merge(rt,l,r);
}
void Insert(void)
{
int x,k;
scanf("%d %d",&x,&k);
if(!k)
return;
Node *l,*r,*p,*q;
x=Rank(pos[x]);
if(k==-1)
Split(rt,x-2,l,r);
else
Split(rt,x-1,l,r);
Split(r,1,p,r),Split(r,1,q,r),Merge(l,l,q),Merge(r,p,r),Merge(rt,l,r);
}
void Ask(void)
{
int x;
scanf("%d",&x);
printf("%d\n",Rank(pos[x])-1);
}
void Query(void)
{
int x;
Node *l,*r,*t;
scanf("%d",&x);
Split(rt,x-1,l,r),Split(r,1,t,r);
printf("%d\n",t->v);
Merge(l,l,t),Merge(rt,l,r);
}
private:
struct Node
{
int v,p,num,size;
Node *ft,*c[2];
Node(int v=0,int p=0,int num=0,int size=0):v(v),p(p),num(num),size(size)
{
ft=c[0]=c[1]=nullptr;
}
~Node(void)
{
if(c[0]!=nullptr)
delete c[0];
if(c[1]!=nullptr)
delete c[1];
}
}*rt,*pos[MAXN];
void Update(Node *i)
{
i->size=1,pos[i->v]=i;
if(i->c[0]!=nullptr)
{
i->size+=i->c[0]->size;
i->c[0]->ft=i;
}
if(i->c[1]!=nullptr)
{
i->size+=i->c[1]->size;
i->c[1]->ft=i;
}
}
void Build(Node *&k)
{
stack<Node *> st;
for(int i=1,t;i<=n;++i)
{
scanf("%d",&t);
Node *x=new Node(t,rand(),i,1);
pos[t]=x,k=nullptr;
while(!st.empty() && x->p>st.top()->p)
Update(k=st.top()),st.pop();
if(!st.empty())
st.top()->c[1]=x;
x->c[0]=k,st.push(x);
}
while(!st.empty())
Update(k=st.top()),st.pop();
}
void Split(Node *i,int x,Node *&l,Node *&r)
{
if(i==nullptr)
{
l=r=nullptr;
return;
}
int t=(i->c[0]!=nullptr ? i->c[0]->size : 0)+1;
if(x<t)
Split((r=i)->c[0],x,l,i->c[0]);
else
Split((l=i)->c[1],x-t,i->c[1],r);
Update(i);
}
void Merge(Node *&i,Node *l,Node *r)
{
if(l==nullptr || r==nullptr)
{
i=l!=nullptr ? l : r;
return;
}
if(l->p>r->p)
Merge((i=l)->c[1],l->c[1],r);
else
Merge((i=r)->c[0],l,r->c[0]);
Update(i);
}
int Rank(Node *i)
{
int ans=(i->c[0]!=nullptr ? i->c[0]->size : 0)+1;
while(i->ft!=nullptr)
{
if(i==i->ft->c[1])
ans+=(i->ft->c[0]!=nullptr ? i->ft->c[0]->size : 0)+1;
i=i->ft;
}
return ans;
}
}*T=new FHQ_Treap;
int main(int argc,char *argv[])
{
scanf("%d %d",&n,&m);
T->Init();
for(int i=1;i<=m;++i)
{
char str[10];
scanf("\n%s",str);
switch(str[0])
{
case 'T':
T->Top();
break;
case 'B':
T->Bottom();
break;
case 'I':
T->Insert();
break;
case 'A':
T->Ask();
break;
case 'Q':
T->Query();
break;
}
}
delete T;
return 0;
}
谢谢阅读。
[Luogu 2596] ZJOI2006 书架的更多相关文章
- fhq_treap || BZOJ1861: [Zjoi2006]Book 书架 || Luogu P2596 [ZJOI2006]书架
题面:P2596 [ZJOI2006]书架 题解:记录每本书对应的节点编号 普通fhq_treap无法查询一个权值的排名,所以在普通fhq_treap上多记录每个节点的父亲(可加在pushup函数中) ...
- 洛谷.2596.[ZJOI2006]书架(Splay)
题目链接 /* 五个操作: 1.将某元素置顶.删掉这个数,插入最左 2.将某元素置底.同样 3.旋到根后,直接将这个数与前驱/后继交换所有信息 不是左右子节点! 4.5.裸平衡树 ps:1.用pos[ ...
- luogu P2596 [ZJOI2006]书架
传送门 感觉要死在\(Splay\)里了 orz 这题用\(Splay\)维护这个序列,其中的第\(k\)大点代表这个序列的第\(k\)个数 第一个操作,先把那个数所在的点旋到根,然后把整个根的左子树 ...
- 「luogu2569」[ZJOI2006] 书架
「luogu2569」[ZJOI2006]书架 题目大意 给定一个长度为 \(n\) 序列,序列中第 \(i\) 个元素有编号 \(a_i(a_i \in \Z \cap [1,n])\),需要支持五 ...
- [ZJOI2006]书架(权值splay)
[ZJOI2006]书架(luogu) Description 题目描述 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看 ...
- 洛谷 P2596 [ZJOI2006]书架 解题报告
P2596 [ZJOI2006]书架 题目描述 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书, ...
- P2596 [ZJOI2006]书架 && Splay 区间操作(三)
P2596 [ZJOI2006]书架 题目描述 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书, ...
- wikioi 1514 and ZJOI2006 书架
1514 书架 0人推荐 收藏 发题解 提交代码 报错 题目描述 输入描述 输出描述 样例输入 样例输出 提示 题目描述 Description 小 T有一个很大的书柜.这个书柜的构造有些独特,即书柜 ...
- [BZOJ1861][ZJOI2006]书架
BZOJ Luogu Description 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书,看 ...
随机推荐
- POJ 3498 March of the Penguins(网络最大流)
Description Somewhere near the south pole, a number of penguins are standing on a number of ice floe ...
- 软件工程part5
1.本周psp 2.本周饼状图 3.本周进度条
- # ML学习小笔记—Classification
关于本课程的相关资料http://speech.ee.ntu.edu.tw/~tlkagk/courses_ML17.html 通过模型可以分类输入,此时根据分类结果的正确与否会有一个Loss函数.找 ...
- 第二章 shell的语法
变量:字符串.数字.环境和参数 获取变量内容可以在变量前使用$字符,使用echo指令可以将变量内容输出到终端. wuchao@wuchao-Lenovo:~$ var=hello wuchao@wuc ...
- Ligerui首页的快速搭建
一.目录 1.多层架构+MVC+EF+AUTOFAC+AUTOMAPPER: 2.MVC中验证码的实现(经常用,记录备用) 3.Ligerui首页的快速搭建 4.Ligerui Grid组件--学生信 ...
- 《Effective C#》快速笔记(六)- - C# 高效编程要点补充
目录 四十五.尽量减少装箱拆箱 四十六.为应用程序创建专门的异常类 四十七.使用强异常安全保证 四十八.尽量使用安全的代码 四十九.实现与 CLS 兼容的程序集 五十.实现小尺寸.高内聚的程序集 这是 ...
- ResultSet 可滚动性和可更新性
JDBC 2.0 API 为结果集增加了两个新的基本能力:可滚动性和可更新性,我想肯定满足了你的要求.在滚动结果集中可用的方法有: rs.previous();//向前滚动 rs.next();//向 ...
- shiro学习详解(开篇)
一.前言 要开始接触公司另外一个项目了,RX和我说了下整个项目框架的结构,其中提到权限的控制是通过shiro来处理的,对我而言又是一个全新的知识点,于是今天花了一点时间去学习shiro的使用,看了好几 ...
- WPF文件和文件夹的操作
1.对文件的操作 private void button_chose_Click(object sender, RoutedEventArgs e) { var openFileDialog = ne ...
- BZOJ 1791 岛屿(环套树+单调队列DP)
题目实际上是求环套树森林中每个环套树的直径. 对于环套树的直径,可以先找到这个环套树上面的环.然后把环上的每一点都到达的外向树上的最远距离作为这个点的权值. 那么直径一定就是从环上的某个点开始,某个点 ...