redblacktree

package
v1.0.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 6, 2024 License: MIT, BSD-2-Clause Imports: 3 Imported by: 0

README

Red Black Trees

Some of the code in this implementation (notably, the implementation of Remove) is inspired by the implementation in GoDS (Go Data Structures). See the license in this directory for licensing.

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrorRotationNotPossible = errors.New("rotation is not possible around node")
)

Functions

func ApplyNodeInorder

func ApplyNodeInorder[T any](node *RedBlackTreeNode[T], f func(item T))

Apply a function f to each node in a tree Inorder.

Apply should not change the item in a Node, as this could affect the tree structure.

func ApplyNodePostorder

func ApplyNodePostorder[T any](node *RedBlackTreeNode[T], f func(item T))

Apply a function f to each node in a tree Postorder.

Apply should not change the item in a Node, as this could affect the tree structure.

func ApplyNodePreorder

func ApplyNodePreorder[T any](node *RedBlackTreeNode[T], f func(item T))

Apply a function f to each node in a tree Preorder.

Apply should not change the item in a Node, as this could affect the tree structure.

func ApplyTreeInorder

func ApplyTreeInorder[T any](tree *RedBlackTree[T], f func(item T))

Apply a function f to each node in a tree Inorder.

Apply should not change the item in a Node, as this could affect the tree structure.

This method is a wrapper for InorderTraversalFold(tree.root, initialAccumulator, f)

func ApplyTreePostorder

func ApplyTreePostorder[T any](tree *RedBlackTree[T], f func(item T))

Apply a function f to each node in a tree Postorder.

Apply should not change the item in a Node, as this could affect the tree structure. This method is a wrapper for PostorderTraversalFold(tree.root, initialAccumulator, f)

func ApplyTreePreorder

func ApplyTreePreorder[T any](tree *RedBlackTree[T], f func(item T))

Apply a function f to each node in a tree Preorder.

Apply should not change the item in a Node, as this could affect the tree structure.

This method is a wrapper for PreorderTraversalFold(tree.root, initialAccumulator, f)

func FoldNodeInorder

func FoldNodeInorder[T, G any](node *RedBlackTreeNode[T], initialAccumulator G, f func(item T, accumulator G) G) G

Fold a function f (taking the current node item and the accumulator value) across the tree Inorder. f must return the next value of the accumulator.

Returns the final accumulator value

func FoldNodePostorder

func FoldNodePostorder[T, G any](node *RedBlackTreeNode[T], initialAccumulator G, f func(item T, accumulator G) G) G

Fold a function f (taking the current node item and the accumulator value) across the tree Postorder. f must return the next value of the accumulator.

Returns the final accumulator value

func FoldNodePreorder

func FoldNodePreorder[T, G any](node *RedBlackTreeNode[T], initialAccumulator G, f func(item T, accumulator G) G) G

Fold a function f (taking the current node item and the accumulator value) across the tree Preorder. f must return the next value of the accumulator.

Returns the final accumulator value

func FoldTreeInorder

func FoldTreeInorder[T, G any](tree *RedBlackTree[T], initialAccumulator G, f func(item T, accumulator G) G) G

Fold a function f over the tree Inorder.

This method is a wrapper for FoldInorder(tree.root, initialAccumulator, f)

func FoldTreePostorder

func FoldTreePostorder[T, G any](tree *RedBlackTree[T], initialAccumulator G, f func(item T, accumulator G) G) G

Fold a function f over the tree Postorder.

This method is a wrapper for FoldPostorder(tree.root, initialAccumulator, f)

func FoldTreePreorder

func FoldTreePreorder[T, G any](tree *RedBlackTree[T], initialAccumulator G, f func(item T, accumulator G) G) G

Fold a function f over the tree preorder.

This method is a wrapper for FoldPreorder(tree.root, initialAccumulator, f)

Types

type RedBlackTree

type RedBlackTree[T any] struct {
	// contains filtered or unexported fields
}

Implement a red black tree.

Like a binary search tree, items stored in nodes, such that all left/right children are respectively smaller/larger than the parent node. Unlike a binary search tree, which may become unbalanced and reduce to a linked list, a red black tree will rebalance itself after each addition or removal such that the maximum height is bounded by the log of the number of items. (BST's are worst case bounded linearly by the number of items).

func New

func New[T any](comparatorFunction comparator.ComparatorFunction[T]) *RedBlackTree[T]

Create a new red-black tree of generic type.

The comparator function (see github.com/hmcalister/Go-DSA/Comparator) defines how the items are ordered when creating the tree. This allows for trees that have any type, rather than just comparable types.

func (*RedBlackTree[T]) Add

func (tree *RedBlackTree[T]) Add(item T) error

Insert a new item into the tree.

Returns a dsa_error.ErrorItemAlreadyPresent error if the item already exists in the tree.

func (*RedBlackTree[T]) Find

func (tree *RedBlackTree[T]) Find(item T) (*RedBlackTreeNode[T], error)

Determines if a given item is present in the tree. If the item is present in the tree, the Node containing that item is returned with nil error. If the item is not present, nil is returned along with a dsa_error.ErrorItemNotFound.

func (*RedBlackTree[T]) Remove

func (tree *RedBlackTree[T]) Remove(item T) error

Remove an item from the tree.

Returns a dsa_error.ErrorItemNotFound if the item is not in the tree.

func (*RedBlackTree[T]) Root

func (tree *RedBlackTree[T]) Root() *RedBlackTreeNode[T]

Get the root the red-black search tree

type RedBlackTreeNode

type RedBlackTreeNode[T any] struct {
	// contains filtered or unexported fields
}

func (*RedBlackTreeNode[T]) Height

func (node *RedBlackTreeNode[T]) Height() int

Get the height of this node, the number of steps from this node to the furthest leaf node.

A leaf node has height 0.

func (*RedBlackTreeNode[T]) Item

func (node *RedBlackTreeNode[T]) Item() T

Get the item of this tree node

BEWARE: Mutating this item (e.g. if this item is a struct, array, etc...) may break the tree structure! Only mutate the result of node.Item() if: i) The type of T is a primitive, such as int, float... in which case the result is copied anyway ii) You can ensure your mutation will not change the ordering based on the tree's ComparatorFunction

func (*RedBlackTreeNode[T]) Left

func (node *RedBlackTreeNode[T]) Left() *RedBlackTreeNode[T]

Get the left child of this node. May be nil.

func (*RedBlackTreeNode[T]) Parent

func (node *RedBlackTreeNode[T]) Parent() *RedBlackTreeNode[T]

Get the parent of this node. May be nil

The root node has a nil parent.

func (*RedBlackTreeNode[T]) Predecessor

func (node *RedBlackTreeNode[T]) Predecessor() *RedBlackTreeNode[T]

Return the predecessor of this node, or nil if there is no successor

func (*RedBlackTreeNode[T]) Right

func (node *RedBlackTreeNode[T]) Right() *RedBlackTreeNode[T]

Get the right child of this node. May be nil.

func (*RedBlackTreeNode[T]) Size

func (node *RedBlackTreeNode[T]) Size() int

Get the size of this Node, the number of items in the subtree rooted at this node

A leaf node has size 1.

func (*RedBlackTreeNode[T]) Successor

func (node *RedBlackTreeNode[T]) Successor() *RedBlackTreeNode[T]

Return the successor of this node, or nil if there is no successor

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL