redblacktree

package
v0.0.0-...-118d4d9 Latest Latest
Warning

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

Go to latest
Published: Mar 13, 2016 License: BSD-2-Clause Imports: 4 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Tree

type Tree struct {
	// contains filtered or unexported fields
}

func NewWith

func NewWith(comparator utils.Comparator) *Tree

Instantiates a red-black tree with the custom comparator.

func NewWithIntComparator

func NewWithIntComparator() *Tree

Instantiates a red-black tree with the IntComparator, i.e. keys are of type int.

func NewWithStringComparator

func NewWithStringComparator() *Tree

Instantiates a red-black tree with the StringComparator, i.e. keys are of type string.

func (*Tree) Clear

func (tree *Tree) Clear()

Removes all nodes from the tree.

func (*Tree) Empty

func (tree *Tree) Empty() bool

Returns true if tree does not contain any nodes

func (*Tree) Get

func (tree *Tree) Get(key interface{}) (value interface{}, found bool)

Searches the node in the tree by key and returns its value or nil if key is not found in tree. Second return parameter is true if key was found, otherwise false. Key should adhere to the comparator's type assertion, otherwise method panics.

func (*Tree) GetMax

func (tree *Tree) GetMax() (value interface{}, found bool)

func (*Tree) GetMin

func (tree *Tree) GetMin() (value interface{}, found bool)

func (*Tree) Keys

func (tree *Tree) Keys() []interface{}

Returns all keys in-order

func (*Tree) Put

func (tree *Tree) Put(key interface{}, value interface{})

Inserts node into the tree. Key should adhere to the comparator's type assertion, otherwise method panics.

func (*Tree) Remove

func (tree *Tree) Remove(key interface{})

Remove the node from the tree by key. Key should adhere to the comparator's type assertion, otherwise method panics.

func (*Tree) RemoveMax

func (tree *Tree) RemoveMax() (value interface{}, deleted bool)

func (*Tree) RemoveMin

func (tree *Tree) RemoveMin() (value interface{}, deleted bool)

func (*Tree) Size

func (tree *Tree) Size() int

Returns number of nodes in the tree.

func (*Tree) String

func (tree *Tree) String() string

func (*Tree) Values

func (tree *Tree) Values() []interface{}

Returns all values in-order based on the key.

Jump to

Keyboard shortcuts

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