初识splay 学splay有一段时间了,一直没写...... 本题是splay模板题,维护一个1~n的序列,支持区间翻转(比如1 2 3 4 5 6变成1 2 3 6 5 4),最后输出结果序列. 模板题嘛......主要了解一下splay的基本操作QwQ 原题地址链接[洛谷P3391文艺平衡树] 1.基本概念 splay是一种二叉搜索树,节点的权值满足lson<p<rson,故可以像其他二叉搜索树一样在树上二分查找某数排名,排名为k的数,以及前驱后继等. 普通的二叉搜索树在面对特殊数据时树…
题目传送门 转载自https://www.cnblogs.com/yousiki/p/6147455.html,转载请注明出处 经典引文 空间效率:O(n) 时间效率:O(log n)插入.查找.删除 创造者:Daniel Sleator 和 Robert Tarjan 优点:每次查询会调整树的结构,使被查询频率高的条目更靠近树根. Tree Rotation   树的旋转是splay的基础,对于二叉查找树来说,树的旋转不破坏查找树的结构.   Splaying   Splaying是Splay…
BZOJ链接 洛谷链接 题意 模板题啦~2 代码 //文艺平衡树 #include <cstdio> #include <algorithm> using namespace std; int const N=1e5+10; int n,m; int rt,fa[N],ch[N][2],siz[N]; bool rev[N]; int wh(int p) {return p==ch[fa[p]][1];} void update(int p) {siz[p]=siz[ch[p][0…
BZOJ链接 洛谷链接 题意简述 模板题啦~ 代码 //普通平衡树(Splay) #include <cstdio> int const N=1e5+10; int rt,ndCnt; int ch[N][2],fa[N],val[N],siz[N],cnt[N]; int wh(int p) {return p==ch[fa[p]][1];} void create(int p,int v) {ch[p][0]=ch[p][1]=fa[p]=0; val[p]=v; cnt[p]=1,siz…
题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 4 1 --by洛谷 http://daniu.luogu.org/problem/show?pid=3391 裸的平衡树反转: 方法是按序列位置为关键字排序: 反转(l,r): 则将l-1置于根处,将r+1作为根的右儿子,这样,r+1的左子树就是需要反转的区间: 然后对r+1的左儿子,反转其左右儿子,并打上线段…
题目链接 Splay基础操作 \(Splay\)上的区间翻转 首先,这里的\(Splay\)维护的是一个序列的顺序,每个结点即为序列中的一个数,序列的顺序即为\(Splay\)的中序遍历 那么如何实现区间翻转呢? 对于一次区间翻转操作\(rev(l,r)\),显然先要找到\(l\)和\(r\)在\(Splay\)中的位置 然后把\(l-1\) \(splay\)到根结点,再把\(r+1\) \(splay\)到\(l\)的右儿子的位置 那么区间\([l,r]\)就到了一个子树上,即\(ch[r+…
模板题. 注意标记即可,另外,涉及区间翻转操作,记得设立首尾哨兵. 1 #include<bits/stdc++.h> 2 using namespace std; 3 const int Maxn=0x3f3f3f3f; 4 const int N=1e5+5; 5 int lc[N],rc[N],fa[N],sze[N],vi[N],pos[N],a[N]; 6 int n,m,x,y,rt,T; 7 8 inline int get(){//快读 9 char ch;bool f=fal…
(这里是Splay基础操作,reserve什么的会在下一篇里面讲) 好久之前就说要学Splay了,结果苟到现在才学习. 可能是最近良心发现自己实在太弱了,听数学又听不懂只好多学点不要脑子的数据结构. 感觉Splay比Treap良心多了——代码真的好写. 对于Splay显然可以维护Treap的所有操作,并且本质是BST. 先看看Splay是怎么维护普通平衡树操作的吧. 首先先定义一些基础的变量(若不作特殊说明这些变量的意义不变) int t[N][2] // t[x][0]表示节点x的左子树,t[…
这一篇博客只讲splay的前一部分的操作(rotate和splay),后面的一段博客咕咕一段时间 后一半的博客地址:[传送门] 前言骚话 为了学lct我也是拼了,看了十几篇博客,学了将近有一周,才A掉模板题和文艺平衡树. 这一片博客就是写了跟我之前有相同处境的小伙伴们.我尽可能的写的简单一点,在带一点自己学习时候的心得和总结.(难免会有一点冗长,大佬勿喷) 吐槽:splay=cosplay=slay(滑稽) 如要转载,请注明出处和作者:https://www.cnblogs.com/chhokm…
讲一下另外的所有操作(指的是普通平衡树中的其他操作) 前一篇的学习笔记连接:[传送门],结尾会带上完整的代码. 操作1,pushup操作 之前学习过线段树,都知道子节点的信息需要更新到父亲节点上. 因为旋转之后有两个节点的儿子和两个节点的父亲被改变了,那么原来的总儿子个数也就是sz就被改变了. 那么我们需要维护sz,就需要pushup操作. 这个东西比较简单. void pushup(int nod) { tr[nod].sz = tr[tr[nod].ch[0]].sz + tr[tr[nod…