红黑树插入删除过程

如果不了解插入、删除原理请先阅读 红黑树。本例是我学习的时候载自网上的例子,并不是自己原创,我只是更详细的演示说明了插入、过程。

一、插入

插入结点:12、1、9、2、0、11、7、19、4、15、18、5、14、13、10、16、6、3、8、17 全程演示

1.插入结点12
1.插入结点12
2.插入结点1
2.插入结点1
3.插入结点9(左-情况2)
3.插入结点9(左-情况2)
4.插入结点2(左-情况1)
4.插入结点2(左-情况1)
5.插入结点0
5.插入结点0
6.插入结点11
6.插入结点11
7.插入结点7(右-情况1)
7.插入结点7(右-情况1)
8.插入结点19
8.插入结点19
9.插入结点4(右-情况2)
9.插入结点4(右-情况2)
10.插入结点15(右-情况1)
10.插入结点15(右-情况1)
11.插入结点18(左-情况2)
11.插入结点18(左-情况2)
12.插入结点5(右-情况1)
12.插入结点5(右-情况1)
13.插入结点14(左-情况1)
13.插入结点14(左-情况1)
14.插入结点13(左-情况3)
14.插入结点13(左-情况3)
15.插入结点10
15.插入结点10
16.插入结点16(右-情况1)
16-1.插入结点16(右-情况1)
16-2.插入结点16(右-情况1)
17.插入结点6(左-情况2)
17.插入结点6(左-情况2)
18.插入结点3(左-情况2)
18.插入结点3(左-情况2)
19.插入结点8(右-情况1)
19.插入结点8(右-情况1)
20.插入结点17(右-情况3)
20.插入结点17(右-情况3)

二、删除

删除结点:12、1、9、2、0、11、7、19、4、15、18、5、14、13、10、16、6、3、8、17 全程演示

1.删除结点12(右-情况4),实际上删除的是结点13所在位置,之后将结点13赋值给结点12所在位置即可
1.删除结点12(右-情况4)
2.删除结点1(左-情况4),实际上删除的是结点0所在位置,之后将结点0赋值给结点1所在位置即可
2.删除结点1(左-情况4)
3.删除结点9(左-情况2),实际上删除的是结点10所在位置,之后将结点10赋值给结点9所在位置即可
3.删除结点9(左-情况2)
4.删除结点2(左-情况2),实际上删除的是结点3所在位置,之后将结点3赋值给结点2所在位置即可
4.删除结点2(左-情况2)
5.删除结点0,删除红色结点,无影响
5.删除结点0
6.删除结点11,实际上删除的是结点13所在位置,之后将结点13赋值给结点11所在位置即可,由于结点13为红色,无影响
6.删除结点11
7.删除结点7,实际上删除的是结点8所在位置,之后将结点8赋值给结点7所在位置即可,由于结点8为红色,无影响
7.删除结点7
8.删除结点19(右-情况4)
8.删除结点19(右-情况4)
9.删除结点4(左-情况2),实际上删除的是结点5所在位置,之后将结点5赋值给结点4所在位置即可
9.删除结点4(左-情况2)
10.删除结点15(左-情况3)
10.删除结点15(左-情况3)
11.删除结点18(右-情况2)
11.删除结点18(右-情况2)
12.删除结点5(左-情况4),实际上删除的是结点3所在位置,之后将结点3赋值给结点5所在位置即可
12.删除结点5(左-情况4)
13.删除结点14(左-情况3),实际上删除的是结点13所在位置,之后将结点13赋值给结点14所在位置即可
13.删除结点14(左-情况3)
14.删除结点13(左-情况2)
14.删除结点13(左-情况2)
15.删除结点10,实际上删除的是结点16所在位置,之后将结点16赋值给结点10所在位置即可
15.删除结点10
16.删除结点16(右-情况1),实际上删除的是结点17所在位置,之后将结点17赋值给结点16所在位置即可
16.删除结点16(右-情况1)
17.删除结点6,实际上删除的是结点8所在位置,之后将结点8赋值给结点6所在位置即可,由于结点8为红色,无影响
17.删除结点6
18.删除结点3(左-情况2)
18.删除结点3(左-情况2)
19.删除结点8
19.删除结点8
20.删除结点17
20.删除结点17
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 数据结构与算法--从平衡二叉树(AVL)到红黑树 上节学习了二叉查找树。算法的性能取决于树的形状,而树的形状取决于...
    sunhaiyu阅读 7,688评论 4 32
  • B树的定义 一棵m阶的B树满足下列条件: 树中每个结点至多有m个孩子。 除根结点和叶子结点外,其它每个结点至少有m...
    文档随手记阅读 13,370评论 0 25
  • 一. 算法之变,结构为宗 计算机在很多情况下被应用于检索数据,比如航空和铁路运输业的航班信息和列车时刻表的查询,都...
    Leesper阅读 7,022评论 13 42
  • 原文链接 二叉查找树 由于红黑树本质上就是一棵二叉查找树,所以在了解红黑树之前,咱们先来看下二叉查找树。 二叉查找...
    非典型程序员阅读 2,854评论 2 5
  • B树 1.前言: 动态查找树主要有:二叉查找树(Binary Search Tree),平衡二叉查找树(Balan...
    铁甲依然在_978f阅读 1,466评论 0 4