红黑树的特性简单记

7.说说红黑树的特性

红黑树:属于不严格平衡二叉树,主要解决了平衡二叉树每次插入、删除节点后需要立马操作保证平衡的特性,从而减低了开销。红黑树不是高度平衡的,算是一种折中,插入最多两次旋转,删除最多三次旋转。
红黑树主要用红黑两种颜色改变了平衡二叉树左右子树高度差必须小于或等于1的规定,红黑树的特点主要如下:

记住:黑根黑叶路同黑,红黑二色红生黑

1.(二色)节点只有两种颜色,红色和黑色
2.(黑根)根节点只能是黑色
3.(黑叶)每个叶子节点也都是黑色
4.(路同黑)每一个节点到该节点的叶子节点的每条路劲上都包含数量相同的黑色节点。
5.(红生黑)如果一个节点是红色的,那么他的子节点必须是黑色。

红黑树在搜索、查找中因为非平衡的原因会稍逊与平衡二叉树,但是红黑树对插入删除的折中处理大大降低了重复平衡的操作开销,从这一点上来看是值得的。这也就是为什么STL中的map、set,java中的TreeSet、HashMap的底层搜索树都是用红黑树的结构来存储数据。

红黑树什么情况需要变色,什么情况需要旋转?
当插入新节点违背了红黑树的定义的时候,尝试把红色节点变为黑色,或者把黑色节点变为红色。
当着色之后也不能符合红黑树的定,就只能通过左旋转和右旋转来使得新树来符合红黑树的定义了。
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值