#include <memory>//智能指针头文件
#include <random>//随机数头文件
#include <iostream>
#include <algorithm>
#include <ctime>//time头文件 template<class T>
struct node
{
T key;
unsigned weight;
std::shared_ptr<node<T>> lchild, rchild, parent;
node(T key, unsigned weight, std::shared_ptr<node<T>> lchild = nullptr,
std::shared_ptr<node<T>> rchild = nullptr, std::shared_ptr<node<T>> parent = nullptr):
key(key)
{
this->weight = weight;
this->lchild = lchild;
this->rchild = rchild;
this->parent = parent;
}
}; template<class T>
class Treap
{
private:
std::shared_ptr<node<T>> root;
std::default_random_engine generator;
std::uniform_int_distribution<int> dis;
void left_rotation(std::shared_ptr<node<T>> a)
{
if (a == nullptr) return; std::shared_ptr<node<T>> b = a->lchild;
if (b == nullptr) return; if (b->rchild != nullptr)
{
a->lchild = b->rchild;
b->rchild->parent = a;
}
else
a->lchild = nullptr;// b->parent = a->parent;
if (a->parent == nullptr)
root = b;
else
{
if (a->parent->lchild == a)
a->parent->lchild = b;
else
a->parent->rchild = b;
} b->rchild = a;
a->parent = b;
}
void right_rotation(std::shared_ptr<node<T>> a)
{
if (a == nullptr) return; std::shared_ptr<node<T>> b = a->rchild;
if (b == nullptr) return; if (b->lchild != nullptr)
{
a->rchild = b->lchild;
b->lchild->parent = a;
}
else
a->rchild = nullptr; b->parent = a->parent;
if (a->parent == nullptr)
root = b;
else
{
if (a->parent->lchild == a)
a->parent->lchild = b;
else
a->parent->rchild = b;
} b->lchild = a;
a->parent = b;
}
public:
Treap() :generator(time(nullptr)), dis(, )
{
root = nullptr;
}
void insert(T key)
{
std::shared_ptr<node<T>> tmp = std::make_shared<node<T>>(key, dis(generator));
std::shared_ptr<node<T>> ptr = root;
if (ptr == nullptr)
{
root = tmp;
return;
} while (true)
{
if (key <= ptr->key)
{
if (ptr->lchild == nullptr) break;
ptr = ptr->lchild;
}
else
{
if (ptr->rchild == nullptr) break;
ptr = ptr->rchild;
}
} if (key <= ptr->key)
ptr->lchild = tmp;
else
ptr->rchild = tmp;
tmp->parent = ptr; while (ptr != nullptr)
{
if (tmp->weight < ptr->weight)
{
if (ptr->lchild == tmp)
{
left_rotation(ptr);
ptr = tmp->parent;
}
else
{
right_rotation(ptr);
ptr = tmp->parent;
}
}
else
break;
}
}
void earse(T key)
{
std::shared_ptr<node<T>> ptr = root;
while (ptr != nullptr)
{
if (key == ptr->key)
break;
else if (key < ptr->key)
ptr = ptr->lchild;
else
ptr = ptr->rchild;
}
if (ptr == nullptr) return;
while (true)
{
if (ptr->lchild == nullptr || ptr->rchild == nullptr)
{
if (ptr->lchild == nullptr && ptr->rchild == nullptr)
{
if (ptr->parent == nullptr) root = nullptr;
else
{
if (ptr->parent->lchild == ptr)
ptr->parent->lchild = nullptr;
else
ptr->parent->rchild = nullptr;
}
}
else if (ptr->lchild == nullptr)
{
if (ptr->parent == nullptr)
root = ptr->rchild;
else
{
if (ptr->parent->lchild == ptr)
ptr->parent->lchild = ptr->rchild;
else
ptr->parent->rchild = ptr->rchild;
}
ptr->rchild->parent = ptr->parent;
}
else
{
if (ptr->parent == nullptr)
root = ptr->lchild;
else
{
if (ptr->parent->lchild == ptr)
ptr->parent->lchild = ptr->lchild;
else
ptr->parent->rchild = ptr->lchild;
}
ptr->lchild->parent = ptr->parent;
}
return;
}
else
{
if (ptr->lchild->weight <= ptr->rchild->weight)
left_rotation(ptr);
else
right_rotation(ptr);
}
}
}
};

平衡数之Treap的更多相关文章

  1. hdu 3709 Balanced Number(平衡数)--数位dp

    Balanced Number Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others) ...

  2. SPOJ BALNUM Balanced Numbers 平衡数(数位DP,状压)

    题意: 平衡树定义为“一个整数的某个数位若是奇数,则该奇数必定出现偶数次:偶数位则必须出现奇数次”,比如 222,数位为偶数2,共出现3次,是奇数次,所以合法.给一个区间[L,R],问有多少个平衡数? ...

  3. hdu3709 (平衡数) 数位DP

    Balanced Number Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others) ...

  4. 简析平衡树(二)——Treap

    前言 学完了替罪羊树,我决定再去学一学\(Treap\).一直听说\(Treap\)很难,我也花了挺久才学会. 简介 \(Treap\)这个名字真的挺有内涵: \(\color{red}{Tree}\ ...

  5. 「算法笔记」旋转 Treap

    一.引入 随机数据中,BST 一次操作的期望复杂度为 \(\mathcal{O}(\log n)\). 然而,BST 很容易退化,例如在 BST 中一次插入一个有序序列,将会得到一条链,平均每次操作的 ...

  6. c++ FHQ Treap

    前面我们对平衡树有了个大概的了解 关于 Treap Treap=Binary Search Tree + Heap 二叉搜索树 + 二叉堆(一般是小根堆) Treap 每一个节点有两个值 一个值是平衡 ...

  7. bzoj1691[Usaco2007 Dec]挑剔的美食家 平衡树treap

    Description 与很多奶牛一样,Farmer John那群养尊处优的奶牛们对食物越来越挑剔,随便拿堆草就能打发她们午饭的日子自然是一去不返了.现在,Farmer John不得不去牧草专供商那里 ...

  8. FHQ Treap及其可持久化与朝鲜树式重构

    FHQ Treap,又称无旋treap,一种不基于旋转机制的平衡树,可支持所有有旋treap.splay等能支持的操作(只有在LCT中会比splay复杂度多一个log).最重要的是,它是OI中唯一一种 ...

  9. HDU 3709 Balanced Number 求区间内的满足是否平衡的数量 (数位dp)

    平衡数的定义是指,以某位作为支点,此位的左面(数字 * 距离)之和 与右边相等,距离是指某位到支点的距离; 题意:求区间内满足平衡数的数量 : 分析:很好这又是常见的数位dp , 不过不同的是我们这次 ...

随机推荐

  1. vue使用axios中 this 指向问题

    1.解决办法 在vue中使用axios做网络请求的时候,会遇到this不指向vue,而为undefined,可以使用箭头函数"=>"来解决.如下: methods: { lo ...

  2. Android-Volley网络通信框架(StringRequest &amp; JsonObjectRequest)

    1.回想 上篇对 Volley进行了简介和对它的学习目的与目标,最后,为学习Volley做了一些准备 2.重点 2.1 RequestQueue 请求队列的建立 2.2 学习 StringReques ...

  3. BZOJ 2730 矿场搭建 Tarjan求割点

    思路: Tarjan求出来点双&割点 判一判就行了 //By SiriusRen #include <stack> #include <cstdio> #include ...

  4. POJ 3257 DP

    题意: 思路: 用vector存上本出发点能到的地方&成本&有趣指数(用结构体保存) 然后DP就好了 f[i][j]表示到了i 成本为j的有趣指数最大是多少 f[vec[i][k].e ...

  5. sqlserver bulk insert

    开启功能 -- To allow advanced options to be changed. EXEC sp_configure 'show advanced options', 1 GO -- ...

  6. Python(六) Python 函数

    一.认识函数 help(方法名字)  help(round) 1.功能性 2.隐藏细节 3.避免编写重复的代码 4.组织代码 自定义函数 二.函数的定义及运行特点 # 递归 def sum_num(n ...

  7. 威联通212P 在admin用户密码正确情况下仍然无法登录WEB页面解决办法

    *登录 telnet 执行以下语句: [~] # cp /etc/default_config/passwd /mnt/HDA_ROOT/.config/passwd[~] # cp /etc/def ...

  8. 今日SGU 5.18

    SGU 125 题意:给你一个数组b[i][j],表示i,j的四周有多少个数字大于它的,问你能不能构造出一个a矩形 收获:dfs  + 剪枝 一行一行的dfs,然后第一行去枚举0-9,下一行判断当前选 ...

  9. SpringBoot 整合 Mybatis 和 Mysql (详细版)

    结构如下 1.引入相关依赖 <!--mysql--><dependency> <groupId>mysql</groupId> <artifact ...

  10. hibernate : object references an unsaved transient instance 问题

    save顺序问题---比如学生表和班级表..学生表里有班级ID的外键.一对多的关系. 你save的时候应该先save班级,再save学生..否则学生的外键没有对应的值,引发异常