红黑树的插入创建(左旋 右旋)
来源:互联网 发布:同步软件 编辑:程序博客网 时间:2024/04/29 18:15
typedef struct node{
int key,color;
struct node *lchild;
struct node *rchild;
struct node *parent;
}Pnode;
结构体类型就是在二叉搜索树的基础上增加了color这个变量
插入操作:
插入的元素默认为红色
除了基本的二叉树元素插入之外还增加了红黑调整满足红黑树的五大性质
假设插入节点为X,无论哪种插入情况只会影响性质2和性质4其中的一个.
1.当红黑树为空树时,此时只需将插入的元素作为根节点并把颜色改成黑色即可
2.当红黑树不为空时,当且仅当插入后,X的父节点与X一样为红色时,违反性质4。
一.当X的叔叔节点(即X的父亲的兄弟节点)为红色时, 将X的爷爷节点改为红色,将X的父节点和叔叔节点改为黑色,并将X的爷爷节点进入下一次调整。
二.当X的叔叔节点为黑色时,如果X为其父节点的左孩子,将其父节点改为黑色,将爷爷节点改成红色并对爷爷节点进行右旋。
三.当X的叔叔节点为黑色时,如果X为其父节点的右孩子,对其父节点进行左旋,再进行第二种情况操作。
代码:
//插入
void insert(Pnode **root,int x)
{
Pnode *p=(Pnode *)malloc(sizeof(Pnode));
p->lchild=p->rchild=p->parent=NULL;
p->color=red;p->key=x;
//如果为空树 违反性质2 因此直接将红色改成黑色即可
if(*root==NULL) {
p->color=black;
*root=p;
return;
}
if((*root)->rchild==NULL&&(*root)->key<x){
(*root)->rchild=p;
p->parent=*root;
insertfix(&p);
return;
}
if((*root)->lchild==NULL&&(*root)->key>x){
(*root)->lchild=p;
p->parent=*root;
insertfix(&p);
return;
}
if((*root)->key<x){
insert(&(*root)->rchild,x);
}
else {
insert(&(*root)->lchild,x);
}
}
//插入调整
void insert(Pnode **root,int x)
{
Pnode *p=(Pnode *)malloc(sizeof(Pnode));
p->lchild=p->rchild=p->parent=NULL;
p->color=red;p->key=x;
//如果为空树 违反性质2 因此直接将红色改成黑色即可
if(*root==NULL) {
p->color=black;
*root=p;
return;
}
if((*root)->rchild==NULL&&(*root)->key<x){
(*root)->rchild=p;
p->parent=*root;
insertfix(&p);
return;
}
if((*root)->lchild==NULL&&(*root)->key>x){
(*root)->lchild=p;
p->parent=*root;
insertfix(&p);
return;
}
if((*root)->key<x){
insert(&(*root)->rchild,x);
}
else {
insert(&(*root)->lchild,x);
}
}
- 红黑树的插入创建(左旋 右旋)
- 在红黑树的基础上实现区间树的创建,左旋,右旋,插入和查找
- 建立红黑树(左旋、右旋、插入、维护)代码+验证
- 序列的左旋右旋
- 字符串的左旋右旋
- 红黑树的理解与学习&左旋与右旋操作
- nyoj202 红黑树 (二叉树的左旋右旋)
- 二叉树的左旋和右旋
- AVL树的左旋右旋理解
- 树的左旋与右旋
- 二叉树的左旋和右旋
- 树的左旋与右旋
- 字符串的左旋和右旋
- 树的左旋和右旋
- 左旋右旋字符串
- 左旋(右旋)字符串
- 实现字符串左旋和右旋的常见方法
- c语言----高位舍弃的左旋和右旋操作
- 【网络流】 HDOJ 4307 Matrix
- LeetCode100 SameTree java题解
- C++对象在内存中的分布
- Wildcard Matching 字符串含?,*匹配
- CentOS安装mysql
- 红黑树的插入创建(左旋 右旋)
- Android apk的启动过程
- 关于技术博客
- 动态树 解题报告
- 简单区分VMware的三种网络连接模式(bridged、NAT、host-only)
- android:layout_gravity和android:gravity的区别
- Asp.Net Ajax4.5 未知的服務器標記 問題
- 欢迎使用CSDN-markdown编辑器
- 使用maven profile实现多环境可移植构建