splay板子整理

本文解析了平衡树的一种特殊实现——Splay Tree,详细介绍了如何通过维护节点信息、splay操作、建树规则和结合其他数据结构来高效地插入、查找和删除元素。从结构到操作,一步步揭示了其在算法中的核心作用。

本质就是个平衡树。
具体到一道题,无非就是要考虑如何
1.每个节点维护什么信息。
2.如何维护splay(top,bottom等splay特色操作)
3.如何建树,建树规则如何实现。如何找到需要的节点。
4.结合其他数据结构(难)

#include <bits/stdc++.h>

using namespace std;
//-----pre_def----
const double PI = acos(-1.0);
const int INF = 0x3f3f3f3f;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PII;
typedef pair<double, double> PDD;
#define fir(i, a, b) for (int i = (a); i <= (b); i++)
#define rif(i, a, b) for (int i = (a); i >= (b); i--)
#define endl '\n'
#define init_h memset(h, -1, sizeof h), idx = 0;
#define lowbit(x) x &(-x)

//---------------
const int N = 1e5 + 10;

struct node //节点信息
{
   
   
    int s[2], p, v, sz;
    //int lz;
} tr[N];
int n, m, root, idx;
void pushup(int u)
{
   
   
    //维护父子之间的信息
    tr[u].sz = tr[tr[u].s[0]].sz + tr[tr[u].s[1]].sz + 1;
}
void rotate(int x)
{
   
   
    int y =
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值