| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 红黑树原理 -> 正文阅读 |
|
[数据结构与算法]红黑树原理 |
一、红黑树定义1、根节点是黑色的。 2、每一个叶子结点都是黑色的 nil 节点,也就是说叶子结点不存放数据。 3、任何相邻节点都不能同为红色节点。红色节点是被黑色节点隔开的。 4、每个节点,从该节点开始到达该节点的叶子结点的任何路径包含相同数目的黑色节点。 二、节点左旋和右旋????????树的左旋 ?????????树的右旋 一、红黑树增加节点增加的节点都是红色节点; 情况一:插入的节点是根节点,不用操作,直接把红色改为黑色即可。 情况二:父节点是黑色节点,不用做任何操作,直接加入即可。 情况三:父节点是红色节点,父节点的兄弟节点也是红色节点; ????????将加入节点的父节点和叔叔节点都变为黑色,父节点的父节点变为红色。 ?情况四:父节点是红色节点,叔叔节点是黑色节点,这种情况分为四种状态; ?状态1:左左 ? ? ? ? ? ? ? ? 节点 x 在左子树的左侧节点,就将父节点 g?右旋 ,然后 p 节点和当前 p 节点的右节点交换颜色; ?状态二:?左右 ? ? ? ? 节点p左旋,变为左左状态,重复左左操作。 ?状态三:右右 ????????将 g 节点左旋,然后 g 节点和父节点交换颜色。 ?状态四:右左 ? ? ? ? 将 p 节点右旋,节点状态变为 右右状态,重复右右操作。 ?三、举例节点新增? ? ? ? 节点加入顺序? :10 ,70,32,34,13,56,21,如下图所有流程。 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 3:20:01- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |