平衡数之Treap
#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的更多相关文章
- hdu 3709 Balanced Number(平衡数)--数位dp
Balanced Number Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others) ...
- SPOJ BALNUM Balanced Numbers 平衡数(数位DP,状压)
题意: 平衡树定义为“一个整数的某个数位若是奇数,则该奇数必定出现偶数次:偶数位则必须出现奇数次”,比如 222,数位为偶数2,共出现3次,是奇数次,所以合法.给一个区间[L,R],问有多少个平衡数? ...
- hdu3709 (平衡数) 数位DP
Balanced Number Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others) ...
- 简析平衡树(二)——Treap
前言 学完了替罪羊树,我决定再去学一学\(Treap\).一直听说\(Treap\)很难,我也花了挺久才学会. 简介 \(Treap\)这个名字真的挺有内涵: \(\color{red}{Tree}\ ...
- 「算法笔记」旋转 Treap
一.引入 随机数据中,BST 一次操作的期望复杂度为 \(\mathcal{O}(\log n)\). 然而,BST 很容易退化,例如在 BST 中一次插入一个有序序列,将会得到一条链,平均每次操作的 ...
- c++ FHQ Treap
前面我们对平衡树有了个大概的了解 关于 Treap Treap=Binary Search Tree + Heap 二叉搜索树 + 二叉堆(一般是小根堆) Treap 每一个节点有两个值 一个值是平衡 ...
- bzoj1691[Usaco2007 Dec]挑剔的美食家 平衡树treap
Description 与很多奶牛一样,Farmer John那群养尊处优的奶牛们对食物越来越挑剔,随便拿堆草就能打发她们午饭的日子自然是一去不返了.现在,Farmer John不得不去牧草专供商那里 ...
- FHQ Treap及其可持久化与朝鲜树式重构
FHQ Treap,又称无旋treap,一种不基于旋转机制的平衡树,可支持所有有旋treap.splay等能支持的操作(只有在LCT中会比splay复杂度多一个log).最重要的是,它是OI中唯一一种 ...
- HDU 3709 Balanced Number 求区间内的满足是否平衡的数量 (数位dp)
平衡数的定义是指,以某位作为支点,此位的左面(数字 * 距离)之和 与右边相等,距离是指某位到支点的距离; 题意:求区间内满足平衡数的数量 : 分析:很好这又是常见的数位dp , 不过不同的是我们这次 ...
随机推荐
- 在ubuntu上使用华为的3G无线上网卡 - usb_modeswitch
众所周知,华为或者中兴的无线上网卡是比较好用的,U盘一样的东西,插进电脑的Usb口就能用,但是,这只是针对windows操作系统而言. 对于linux系统,该设备是无法自动加载驱动的. 因此,需要用到 ...
- Win10 + YOLOv3训练VOC数据集-----How to train Pascal VOC Data
How to train (Pascal VOC Data): Download pre-trained weights for the convolutional layers (154 MB): ...
- 洛谷 P2440 木材加工
P2440 木材加工 题目背景 要保护环境 题目描述 题目描述: 木材厂有一些原木,现在想把这些木头切割成一些长度相同的小段木头(木头有可能有 剩余),需要得到的小段的数目是给定的.当然,我们希望得到 ...
- POJ 1258 Agri-Net (最小生成树+Prim)
Agri-Net Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 39820 Accepted: 16192 Descri ...
- (hdu step 7.2.1)The Euler function(欧拉函数模板题——求phi[a]到phi[b]的和)
题目: The Euler function Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- 线程池系列一:线程池作用及Executors方法讲解
线程池的作用: 线程池作用就是限制系统中执行线程的数量. 根据系统的环境情况,可以自动或手动设置线程数量,达到运行的最佳效果:少了浪费了系统资源,多了造成系统拥挤效率不高.用线程池控制线程数量 ...
- .Net 断点调试
设置断点,F11逐句查看,F10逐过程查看. 通过断点,可以查看程序走的过程,可以更清晰程序的流程. 通过断点,可以查看属性的值情况,判断哪里出了问题. 不过,只适用于pc端调试,浏览器访问才会触发. ...
- Codeforces Round#320 Div2 解题报告
Codeforces Round#320 Div2 先做个标题党,骗骗访问量,结束后再来写咯. codeforces 579A Raising Bacteria codeforces 579B Fin ...
- Sub Thread to update main Thread (UI) 2
Sub Thread to update main Thread (UI) 2 Handler.post(somethread); Handler.sendMessage("Msg&quo ...
- selenium无法定位元素问题
在用自动化测试工具selenium完成下载任务时,经常会遇到定位不到元素的情况,总结如下: 1.frame/iframe原因定位不到元素: 这个是最常见的原因,首先要理解下frame的实质,frame ...