红黑树(Red Black Tree) - Flex实现

红黑树(Red Black Tree) - Flex实现  

2011-12-06 19:51:50|  分类: 课程学习 |  标签:学习  算法  flex  |字号 订阅

    这学期算法课的一个作业,逻辑代码都是对着伪码敲出来的,时间仓促,界面和表现效果都写得比较简陋。学习红黑树之前最好先学习下AVL树,了解AVL的性质以及旋转(左单旋、右单旋、左右双旋、右左双旋)等操作。

什么是红黑树

    红黑树是一种自平衡二叉查找树,典型的用途是实现关联数组。红黑树的实现是复杂的,但是它有着良好的时间运行效率,在实际应用中是很高效的,可以在O(logn)时间内做查找、插入和删除操作,在这里n是指树的节点数目。

  红黑树是AVL树的变种红黑树通过一些着色法则确保没有一条路径会比其它路径长出两倍,因而达到接近平衡目的。

用途

  • 红黑树和 AVL 树一样都对插入时间、删除时间和查找时间提供了良好的时间效率担保。这不只是使它们在时间敏感的应用如实时应用 (real time application) 中有价值,而且使它们有在提供最坏情况担保的其他数据结构中作为建造板块的价值;例如,在计算几何中使用的很多数据结构都可以基于红黑树
  • 红黑树在函数式编程中也特别有用,在这里它们是最常用的持久数据结构之一,它们用来构造关联数组和集合,在突变之后它们能保持为以前的版本。除了 O(logn) 的时间之外,红黑树的持久版本对每次插入或删除需要 O(log n) 的空间。
  • 红黑树是  2-3-4 树的一种等同。换句话说,对于每个  2-3-4  树,都存在至少一个数据元素是同样次序的红黑树。在  2-3-4  树上的插入和删除操作也等同于在红黑树中颜色翻转和旋转。 2-3-4  树在实践中不经常使用。

性质

  红黑树是每个节点都带有颜色属性的二叉查找树,颜色为红色黑色。在二叉查找树强制一般要求以外,对于任何有效的红黑树还有如下的额外要求:

  • 性质 1.  节点是红色或黑色。
  • 性质 2.  根是黑色。
  • 性质 3.  所有叶子都是黑色(叶子是 NIL 节点)。
  • 性质 4.  每个红色节点的两个子节点都是黑色。 ( 从每个叶子到根的所有路径上不能有两个连续的红色节点 )
  • 性质 5.  从任一节点到其每个叶子的所有简单路径都包含相同数目的黑色节点。

操作

    红黑树最复杂的操作是插入删除,其中删除操作是最复杂的。插入操作需要考虑六种情况,其中三种情况和另外三种情况是对称的,只是插入的新节点z的父节点是在其祖父节点的左子树还是在右子树的区别。而当删除操作删除的节点的子节点x是黑色的时候,则需要考虑八种情况,其中四种情况是和另外四种是对称的,只是x是其父节点的右孩子还是左孩子的区别。具体描述和操作可以参考以下链接:

Flex实现的程序

  • 程序主要用于演示红黑树的原理,写得很简陋,使用的时候需要注意几点:
    • 只支持正整型数据
    • 不支持重复值
  • 程序截图:

红黑树 - Flex实现 - 小木舟 - 小木舟的博客 

参考

   本文章参考了 http://zh.wikipedia.org/wiki/红黑树 。

推荐

   红黑树可视化演示的一个非常好的程序,见这里: http://www.cs.usfca.edu/~galles/visualization/flash.html 。
 评论这张
转发至微博
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值