HashMap 数据结构之红黑树, 红黑树在什么时候左旋 右旋 如何旋转

article/2025/9/28 15:19:26

       树结构是数据结构中最经典最常用的结构之一,也是面试中常问的面试题,最近学习了一下红黑树的知识,记录整理一下

文章目录

  • 一、红黑树的特征
  • 二、变色左旋和右旋
    • 1.变色规则
    • 2.左旋
    • 3.右旋
  • 总结

 


前言

         面试中我们经常会被问到 HashMap 在 1.7 和 1.8 的区别,在 jdk 1.8 中,当链表的长度超过8 数组长度大于64时数据结构改为了红黑树 ,当新插入一个值的时候,红黑树可能会进行变色 左旋 右旋的操作, 这里对红黑树在什么情况下进行 变色 左旋 右旋 的操作做一下整理


一、红黑树的特征

(1)每个节点或者是黑色,或者是红色

(2)根节点是黑色

(3)每个红色节点的两个子节点都是黑色。( 即: 不能有两个连续的红色节点 )

(4)从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点

二、变色左旋和右旋

1. 变色规则

 当前结点的父亲是红色,且它的祖父结点的另一个子结点也是红色(叔叔结点):

(1)把父节点设为黑色

(2)把叔叔也设为黑色

(3)把祖父也就是父亲的父亲设为红色(爷爷)

(4)把指针定义到祖父结点设为当前要操作的(爷爷)分析的点变换的规则

这里我们新插入一个值 6  ( 插入的节点都是红色的 所以 6 是红色的节点 ) ,变色后的图形

2.左旋

当前父结点是红色,叔叔是黑色的时候,且当前的结点是子树。左旋 

左旋动态图  ( 爷爷从上面回来 爸爸从下面上去 以前挂靠着爸爸 现在挂靠着爷爷 )

当前结构不满足红黑色,这里做一下左旋 

 

3.右旋

 当前父结点是红色,叔叔是黑色的时候,且当前的结点是子树。右旋 

(1)把父节点变为黑色

(2)把祖父结点变为红色(爷爷)

(3)把祖父结点旋转(爷爷)

右旋动态图

当前结构不满足红黑色,这里进行一下右旋 

 

 


总结

  以上是关于红黑树变色 左旋 右旋的一些规则,也是面试中常见的问题之一,这里对学习红黑树后做一下整理记录

 

 


http://chatgpt.dhexx.cn/article/Xmj4Kom4.shtml

相关文章

java平衡二叉树左旋,Java 平衡二叉树之单旋(左旋,右旋)与双旋

1.平衡二叉树 平衡二叉树也叫平衡二叉搜索树(Self-balancing binary search tree)又被称为AVL树, 可以保证查询效率较高。 具有以下特点:它是一 棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。 首先…

平衡二叉树的左旋和右旋

文章目录 复习树1. 树的概念2. 二叉树(Binary Tree)3. 满二叉树4. 完全二叉树5. 二叉堆6. 二叉搜索树 左旋和右旋7. 平衡二叉树(平衡二叉搜索树) 本文章是我的库存文章,本来不发的,但还是发吧,请跳到第7节,那才是讲左旋和右旋的。…

HashMap-红黑树插入平衡、左旋、右旋源码解析

目录 一、树的演变 二、红黑树 1.红黑树的特点 2.树左旋右旋的过程 3.红黑树插入节点情景分析: 三、HashMap插入平衡、左旋、右旋源码解析 1.添加值 2.插入平衡 3.左旋、右旋 一、树的演变 为什么会有树,因为链表的查询效率是logOn,树的查询效率…

HashMap底层实现原理:红黑树左旋右旋

HashMap中的红黑树左旋、右旋: 一、什么是左旋、右旋: 红黑树的性质: 每个节点要么是黑色,要么是红色根节点是黑色每个叶子节点(NIL)是黑色每个红色结点的两个子结点一定都是黑色任意一结点到每个叶子结点…

平衡二叉查找树(AVL)的构建——左旋右旋

原文链接:https://www.cnblogs.com/ZhaoxiCheung/p/6012783.html 平衡二叉树,又称AVL(Adelson-Velskii和Landis)树,是带有平衡条件的二叉查找树。这个平衡条件必须要容易保持,而且它必须保证树的深度是 O&…

详解红黑树之左旋右旋

为什么要左旋右旋? 为了使得左右子树的高度差在一定范围内,需要通过旋转调整,这样就可以保持平稳的搜索效率 左旋: 步骤 1.设原来E的父节点是father,那么左旋之后需要改变的是: 2.S和father的关系&#…

avl树左旋右旋的理解

一直没搞懂非平衡二叉树变平衡二叉树时左旋右旋,今天下定决心搞懂,然后在众多博客中终于找到了这样一篇,非常形象,记录如下: AVL树是最先发明的自平衡二叉查找树。在AVL树中任何节点的两个子树的高度最大差别为一&…

搞懂平衡二叉树的左旋右旋双旋(Java实现)

刚看到韩顺平老师的数据结构与算法对于平衡二叉树的讲解(最后会附上地址),有如下理解,希望能帮助大家!哪里需要改正的欢迎指正! 平衡二叉树:一种二叉排序树(BST Binary Sort Tree&a…

图示讲解AVL平衡二叉树的左旋和右旋

AVLTree 高度平衡的搜索二叉树 一棵平衡树,或是空树,或是具有以下性质的二叉搜索树:左子树和右子树都是AVL树,且左右子树的高度之差的绝对值不超过1。 该二叉树,根结点的右子树高度为3,左子树高度为2。…

左右旋对比

目录 前言 一,逆置法 1.1逆置思路 1.2逆置实现 二,左旋和右旋对比 右旋代码分析 特点对比 前言 之前在up主的博客里面已经有过了对于左旋的三种实现方法。当然,如果我们考虑到时间复杂度的问题,那么我们只要一种方法&#xf…

平衡二叉树的左旋右旋详解 看不懂你打我

平衡二叉树的左旋右旋 看不懂你打我 左旋右旋的操作为什么要左旋右旋左旋右旋能保持排序二叉排序树的性质吗下次写平衡二叉树的LL、RR、LR、RL。 左旋右旋的操作 1.左旋:对X节点左旋,即以X的右孩子Y为轴,将X节点转下来,变为Y的左…

二叉树的旋转,左旋和右旋

在AVLTree中经常会有以某个节点为点对子树进行旋转的操作,今天就和大家分享一下什么是二叉树的旋转。 这是一棵二叉树,上图称为图一。 将图一中的树以1为旋转点进行左旋后得到图二: 将图一中的树以1为旋转点进行右旋旋后得到图三&#xff1…

day062:平衡二叉树——左旋、右旋

二叉树、平衡二叉树的介绍:day061:二叉树、二叉查找树、平衡二叉树_ZQyyds:)的博客-CSDN博客 目录 一、平衡二叉树的左旋 1.为什么要左旋、右旋? 2.什么是左旋? 3.图解 二、平衡二叉树的右旋 1.什么是…

大型json文件格式化【超简单】

问题 遇到了一个很大的JSON文件(约4M),想格式化查看,在线json工具会直接崩溃,网上其他同学说的python方法之类的我也都实验失败,但是发现了vs code中一个超强的代码格式化 解决1(2019.2.10更…

Unity存档系统——Json格式的文件

实例场景 点击Save按钮后,查看保存的文件 点击Load按钮后加载文档数据 Json介绍https://www.json.org/json-zh.htmlUnity中自带的JsonUtility可以将可序列化对象与Json格式相互转换。 将对象转为可序列化对象需要添加[SerializeField],且为public&#…

将json文件格式转化成Excel表格形式

在程序员的工作中,经常有产品或者运营部门的小姐姐需要数据,由于不懂技术,就需要我们将Json格式的数据转换成Excel文档提供给她们进行数据分析。 本文就介绍一个非常简单方便的方法 1.运用的是Excel表格自带的功能 首先打开Excel文件 点击插…

js导出JSON格式文件

在src目录下新建tools文件价,在tools文件中新建index.js(文件内名字随意) 在index.js文件中 const Tools {// 导出文件exportJson(name, data) {let blob new Blob([data]); // 创建 blob 对象let link document.createElement("a");link.href URL.…

json文件

认识一下 json文件 直接使用记事本打开:例如猫狗二分类 一般都使用类似字典的方式存储,但和字典不同,无论是键还是值,都要加上双引号。 json文件的读取与写入 import jsondata {"a":"1","b":&q…

JSON格式校验工具

经常用ApiPost 和 Postman 测试自己写的接口的话,有时会不小心写错传进去的json对象,我们可以用json格式检验工具去检查一下自己json格式。 在线工具:在线 JSON 工具,JSON 校验/格式化/压缩/工具 - 在线工具-wetools.com微工具