红黑树的插入创建(左旋 右旋)

原创 2015年07月06日 20:56:54
红黑树是每个节点都带有颜色属性的二叉查找树,颜色或红色或黑色。除了二叉查找树的性质,同时还有以下的五大性质:
性质1. 节点是红色或黑色。
性质2. 根节点是黑色。
性质3 每个叶节点(NIL节点,空节点)是黑色的。
性质4 每个红色节点的两个子节点都是黑色。(从每个叶子到根的所有路径上不能有两个连续的红色节点)
性质5. 从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点。
         建立红黑树是在建立二叉查找树的基础上进行调整得到的 
       由于也是勉强理解 需要写下自己的见解以免忘记
        

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);

    }

}


版权声明:本文为博主原创文章,未经博主允许不得转载。

一步一图一代码,一定要让你真正彻底明白红黑树

一步一图一代码,一定要让你真正彻底明白红黑树   作者:July   二零一一年一月九日 ----------------------------- 本文参考: I、  The ...

重温数据结构:深入理解红黑树

读完本文你将了解到: 什么是红黑树黑色高度 红黑树的 5 个特性 红黑树的左旋右旋 指定节点 x 的左旋 右图转成左图 指定节点 y 的右旋左图转成右图 红黑树的平衡插入 二叉查找树的插入 插入后调整...

【git】SSH keys 生成,管理多个 SSH keys ,代码第一次提交到远程仓库

1. 生成一个新的 SSH key 并添加到 ssh-agent  ,翻译自 github help 步骤: 生成一个新的 SSH key ①  安装 Git ,打开 Git Bash; ② ...

【gradle】从零开始学习

1.认识            ★ 简单来说就是一款构建工具。            ★ gradle 的特色:                           ① : 声明式的构建和基于约定的构...

在红黑树的基础上实现区间树的创建,左旋,右旋,插入和查找

题目:在红黑树的基础上实现区间树的创建,左旋,右旋,插入和查找 算法思想: 区间树介绍:       区间树是在红黑树基础上进行扩展得到的支持以区间为元素的动态集合的操作,其中每个节点的关键值...

建立红黑树(左旋、右旋、插入、维护)代码+验证

关于红黑树的理论讲解,网上有很多,大家可以自己找,这里重点在于实现一下,代码供大家参考。...
  • xd_huch
  • xd_huch
  • 2014年10月22日 00:39
  • 621

树(二叉树、红黑树及左旋右旋等调整操作)

树(二叉树、红黑树及左旋右旋等调整操作)      在分析Java集合类源码的时候涉及到了树的知识,发现树结构要比数组和链表等要复杂的多,所以巩固和补充一下自己这块的知识。      树(Tr...

nyoj202 红黑树 (二叉树的左旋右旋)

题目202 题目信息 运行结果 本题排行 讨论区 红黑树 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述 什...

平衡二叉树创建,左旋,右旋,左平衡和右平衡

有了上一篇的二级指针优化,平衡二叉树的左旋,右旋,左平衡和右平衡就会简单一些。强烈建议你先看一下: http://blog.csdn.net/wsrspirit/article/details/51...

平衡二叉树(AVL树)一图一步骤代码实现左旋右旋,左右平衡操作

/** * 类说明:AVL树 */ public class AVLTreeE extends ComparableE>> { NodeE> root; int size = ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:红黑树的插入创建(左旋 右旋)
举报原因:
原因补充:

(最多只允许输入30个字)