当前位置: 首页 > news >正文

深圳企业管理培训查询合肥网络公司seo

深圳企业管理培训查询,合肥网络公司seo,网站架构的重要性,怎样做班级网站文章目录 红黑树1 基本概念1.1 定义1.2 基本特性推理1.3 对比1.4 延伸1.4.1 简单判别是否是红黑树1.4.2 应用 2 插入2.1 插入结点默认红色2.2 插入结点2.2.1 插入结点是根结点2.2.2 插入结点的叔叔是红色2.2.3 插入结点的叔叔是黑色场景分析LL型RR型LR型RL型 3 构建4 示例代码 …

文章目录

  • 红黑树
    • 1 基本概念
      • 1.1 定义
      • 1.2 基本特性推理
      • 1.3 对比
      • 1.4 延伸
        • 1.4.1 简单判别是否是红黑树
        • 1.4.2 应用
    • 2 插入
      • 2.1 插入结点默认红色
      • 2.2 插入结点
        • 2.2.1 插入结点是根结点
        • 2.2.2 插入结点的叔叔是红色
        • 2.2.3 插入结点的叔叔是黑色
          • 场景分析
            • LL型
            • RR型
            • LR型
            • RL型
    • 3 构建
    • 4 示例代码

红黑树

1 基本概念

1.1 定义

红黑树首先是二叉搜索树(左<根<右);
基本性质:

  1. 结点非红即黑;
  2. 根/叶子都是黑;
  3. 任意节点向下的所有路径上存在黑结点数量一致;
  4. 红结点下不能直连红结点;

1.2 基本特性推理

  • 最长路径不超过最短路径的两倍;

1.3 对比

与AVL树对比:

AVLRB
高度任一结点左右子树的高度差绝对值不超过1任一结点左右子树的高度差不超过两倍
查询效率(相对)稍高 O(lg n)稍低 O(lg n)
插入/删除效率(相对)

1.4 延伸

1.4.1 简单判别是否是红黑树
1
4
10
13
17
19
25
28
31
  • 答案:否
    • 如果添加NIL结点,发现某一结点下路径的黑结点数量并不相同
1.4.2 应用
  • c++ stl中的map/set 是基于红黑树实现的

2 插入

2.1 插入结点默认红色

  • 如果默认黑色,首先就会破坏黑高同原则,调整相对比较麻烦;
  • 默认红色,可能破坏不红红原则或根为黑原则,调整相对容易;

2.2 插入结点

如果红黑树性质被破坏,分三种情况调整:

2.2.1 插入结点是根结点
  • 违反根为黑原则
  • 调整方案:直接变黑
2.2.2 插入结点的叔叔是红色

示例1:插入结点1

1
5
7
8

调整方案:

  • father 和 uncle 变红,grandpather 变黑
  • grandfather变为插入结点,继续判断是否违反原则
1
5
7
8
2.2.3 插入结点的叔叔是黑色

示例:插入结点1

1
5
7
该情况下,uncle可能直观上不存在,但是红黑树默认有NIL结点,是黑的

调整方案:

  • 根据不同场景(LL/LR/RR/RL)进行旋转,然后变色
场景分析
LL型
1
5
7
NULL

step 1:基于grandfather右旋

1
5
7

step 2:变色

1
5
7
RR型

在这里插入图片描述

step 1:基于grandfather进行左旋
在这里插入图片描述
step 2:变色
在这里插入图片描述

LR型

在这里插入图片描述
调整方案:
在这里插入图片描述

RL型

在这里插入图片描述
调整方案:
在这里插入图片描述

3 构建

按照二叉搜索树规则,依次插入结点,并根据插入规则进行调整

4 示例代码

根据算法导论伪代码实现:

#pragma once#include <iostream>
#include <functional>enum Color {RED, BLACK};struct RBNode {int key;Color color;RBNode *left;RBNode *right;RBNode *parent;
};class RBTree {
private:RBNode *root;RBNode *NIL;void LeftRotate(RBNode *x) {RBNode *y = x->right;x->right = y->left;if (x->right != NIL) {x->right->parent = x;}y->parent = x->parent;if (x->parent == NIL) {root = y;} else if (x == x->parent->left) {x->parent->left = y;} else {x->parent->right = y;}x->parent = y;y->left = x;}void RightRotate(RBNode *y) {RBNode *x = y->left;y->left = x->right;if (y->left != NIL) {y->left->parent = y;}x->parent = y->parent;if (y->parent == NIL) {root = x;} else if (y->parent->left = y) {y->parent->left = x;} else {y->parent->right = x;}y->parent = x;x->right = y;}void InsertFixup(RBNode *z) {while (z->parent->color == RED) {if (z->parent == z->parent->parent->left) {RBNode *y = z->parent->parent->right;if (y->color == RED) {z->parent->color = BLACK;y->color = BLACK;z->parent->parent->color = RED;z = z->parent->parent;} else {if (z == z->parent->right) {z = z->parent;LeftRotate(z);}z->parent->color = BLACK;z->parent->parent->color = RED;RightRotate(z->parent->parent);}} else {RBNode *y = z->parent->parent->left;if (y->color == RED) {z->parent->color = BLACK;y->color = BLACK;z->parent->parent->color = RED;z = z->parent->parent;} else {if (z == z->parent->left) {z = z->parent;RightRotate(z);}z->parent->color = BLACK;z->parent->parent->color = RED;LeftRotate(z->parent->parent);}}}root->color = BLACK;}void Transplant(RBNode *u, RBNode *v) {if (u->parent == NIL) {root = v;} else if (u == u->parent->left) {u->parent->left = v;} else {u->parent->right = v;}v->parent = u->parent; // if v is nullptr or NIL}void DeleteFixup(RBNode *x) {while (x != root && x->color == BLACK) {if (x == x->parent->left) {RBNode *w = x->parent->right;if (w->color == RED) {w->color = BLACK;x->parent->color = RED;LeftRotate(x->parent);w = x->parent->right;}if (w->left->color == BLACK && w->right->color == BLACK) {w->color = RED;x = x->parent;} else {if (w->right->color == BLACK) {w->left->color = BLACK;w->color = RED;RightRotate(w);w = x->parent->right;}w->color = x->parent->color;x->parent->color = BLACK;w->right->color = BLACK;LeftRotate(x->parent);x = root;}} else {RBNode *w = x->parent->left;if (w->color == RED) {w->color = BLACK;x->parent->color = RED;RightRotate(x->parent);w = x->parent->left;}if (w->right->color == BLACK && w->left->color == BLACK) {w->color = RED;x = x->parent;} else {if (w->left->color == BLACK) {w->right->color = BLACK;w->color = RED;LeftRotate(w);w = x->parent->left;}w->color = x->parent->color;x->parent->color = BLACK;w->left->color = BLACK;RightRotate(x->parent);x = root;}}}x->color = BLACK;}RBNode* Minimum(RBNode *node) {while (node->left != NIL) {node = node->left;}return node;}public:RBTree() {NIL = new RBNode{0, BLACK, nullptr, nullptr, nullptr};root = NIL;}~RBTree() {std::function<void(RBNode *)> deleteNode = [&](RBNode *node) {if (node != NIL) {deleteNode(node->left);deleteNode(node->right);delete node;}};deleteNode(root);delete NIL;}void Insert(int key) {RBNode *z = new RBNode{key, RED, NIL, NIL};RBNode *y = NIL;RBNode *x = root;while (x != NIL) {y = x;if (z->key < x->key) {x = x->left;} else {x = x->right;}}z->parent = y;if (y == NIL) {root = z;} else if (z->key < y->key) {y->left = z;} else {y->right = z;}InsertFixup(z);}void Remove(int key) {RBNode *z = root;while (z != NIL && z->key != key) {if (key < z->key) {z = z->left;} else {z = z->right;}}if (z == NIL) {return;}RBNode *y = z;RBNode *x;Color yOriColor = y->color;if (z->left == NIL) {x = z->right;Transplant(z, z->right);} else if (z->right == NIL) {x = z->left;Transplant(z, z->left);} else {y = Minimum(z->right);yOriColor = y->color;x = y->right;if (y->parent == z) {x->parent = y;} else {Transplant(y, y->right);y->right = z->right;y->right->parent = y;}Transplant(z, y);y->left = z->left;y->left->parent = y;y->color = z->color;}delete z;if (yOriColor == BLACK) {DeleteFixup(x);}}void Inorder() {InorderHelper(root);std::cout << std::endl;}void InorderHelper(RBNode* node) {if (node != NIL) {InorderHelper(node->left);std::cout << node->key << " (" << (node->color == RED ? "R)" : "B)") << " ";InorderHelper(node->right);}}
};
http://www.cadmedia.cn/news/4869.html

相关文章:

  • 农产品的网站建设方案书范文深圳全网推广排名
  • 企业网站建设试题合肥网络推广软件系统
  • 西安的商城网站建设关键词录入榜
  • 青岛网站建设代理加盟百度上做优化
  • 集团官方网站建设推广app平台
  • 慈溪市建设局网站搜索引擎关键词怎么选
  • 什么是cms网站系统百度引擎
  • 高端学校网站建设现在搜什么关键词能搜到网站
  • 烟台装修公司网站建设百度seo优化排名客服电话
  • 网站备案注销申请书无锡营销型网站制作
  • 赚钱秒到账的游戏优化技术
  • 宜昌建设厅网站制作网页的基本步骤
  • 西安商城网站建设制作seo建站工具
  • 网站建设工培训机构还能开吗
  • 典型的b2b平台有哪些汕头seo
  • 免费网站封装app知道百度
  • 30天网站建设 视频教程活动推广文案
  • 网站建设一般多少钱比较合适爱站网爱情电影网
  • 超市网站规划网站推广的内容
  • 网站建设松江网站推广如何收费
  • 怎么去建设微信网站网站推广的6个方法是什么
  • 云南省建设厅网站舉報北京网站营销与推广
  • 农业推广网站建设最佳磁力吧ciliba磁力链
  • 绥化网站建设惠州短视频seo
  • 比亚迪新能源汽车价格班级优化大师的优点
  • 网络建设设计咨询搜索引擎seo如何赚钱
  • 检察院门户网站建设工作成效淘宝店铺转让价格表
  • 网站建设 教程网络seo公司
  • 加强网站建设的措施网络推广外包
  • 西藏住房和城乡建设部网站搭建网站工具