etcd/pkg/adt
Matthieu MOREL cad3fce1a0 fix: use testify instead of t.Fatal or t.Error in pkg package
Signed-off-by: Matthieu MOREL <matthieu.morel35@gmail.com>
2025-02-02 16:30:18 +01:00
..
img pkg/adt: README "IntervalTree.Delete" test case images 2019-07-31 10:05:32 -07:00
adt.go package adt: rename the filename to be consistent with the package name (#12170) 2020-07-28 14:40:34 -07:00
example_test.go pkg: Rename imports after making 'pkg' a module 2020-10-13 00:09:27 +02:00
interval_tree_test.go fix: use testify instead of t.Fatal or t.Error in pkg package 2025-02-02 16:30:18 +01:00
interval_tree.go fix: enable gofmt and whitespace linters 2024-10-11 07:03:18 +02:00
README.md pkg: Rename imports after making 'pkg' a module 2020-10-13 00:09:27 +02:00

Red-Black Tree

"Introduction to Algorithms" (Cormen et al, 3rd ed.), Chapter 13

  1. Every node is either red or black.
  2. The root is black.
  3. Every leaf (NIL) is black.
  4. If a node is red, then both its children are black.
  5. For each node, all simple paths from the node to descendant leaves contain the same number of black nodes.

For example,

import (
    "fmt"

    "go.etcd.io/etcd/pkg/v3/adt"
)

func main() {
    ivt := adt.NewIntervalTree()
    ivt.Insert(NewInt64Interval(510, 511), 0)
    ivt.Insert(NewInt64Interval(82, 83), 0)
    ivt.Insert(NewInt64Interval(830, 831), 0)
    ...

After inserting the values 510, 82, 830, 11, 383, 647, 899, 261, 410, 514, 815, 888, 972, 238, 292, 953.

red-black-tree-01-insertion.png

Deleting the node 514 should not trigger any rebalancing:

red-black-tree-02-delete-514.png

Deleting the node 11 triggers multiple rotates for rebalancing:

red-black-tree-03-delete-11.png red-black-tree-04-delete-11.png red-black-tree-05-delete-11.png red-black-tree-06-delete-11.png red-black-tree-07-delete-11.png red-black-tree-08-delete-11.png red-black-tree-09-delete-11.png

Try yourself at https://www.cs.usfca.edu/~galles/visualization/RedBlack.html.