Show / Hide Table of Contents

    Class RedBlackTree<T>

    A red black tree implementation.

    Inheritance
    Object
    RedBlackTree<T>
    Implements
    IEnumerable<T>
    IEnumerable
    Inherited Members
    Object.ToString()
    Object.Equals(Object)
    Object.Equals(Object, Object)
    Object.ReferenceEquals(Object, Object)
    Object.GetHashCode()
    Object.GetType()
    Object.MemberwiseClone()
    Namespace: Advanced.Algorithms.DataStructures
    Assembly: Advanced.Algorithms.dll
    Syntax
    public class RedBlackTree<T> : IEnumerable<T>, IEnumerable where T : IComparable
    Type Parameters
    Name Description
    T

    Constructors

    RedBlackTree(Boolean, IEqualityComparer<T>)

    Constructor

    Declaration
    public RedBlackTree(bool enableNodeLookUp = false, IEqualityComparer<T> equalityComparer = null)
    Parameters
    Type Name Description
    Boolean enableNodeLookUp

    Enabling lookup will fasten deletion/insertion/exists operations at the cost of additional space.

    IEqualityComparer<T> equalityComparer

    Properties

    Count

    Declaration
    public int Count { get; }
    Property Value
    Type Description
    Int32

    Methods

    Delete(T)

    Time complexity: O(log(n))

    Declaration
    public void Delete(T value)
    Parameters
    Type Name Description
    T value

    GetEnumerator()

    Declaration
    public IEnumerator<T> GetEnumerator()
    Returns
    Type Description
    IEnumerator<T>

    GetHeight()

    Time complexity: O(log(n))

    Declaration
    public int GetHeight()
    Returns
    Type Description
    Int32

    HasItem(T)

    Time complexity: O(log(n))

    Declaration
    public bool HasItem(T value)
    Parameters
    Type Name Description
    T value
    Returns
    Type Description
    Boolean

    Insert(T)

    Time complexity: O(log(n))

    Declaration
    public void Insert(T value)
    Parameters
    Type Name Description
    T value

    Max()

    Time complexity: O(log(n))

    Declaration
    public T Max()
    Returns
    Type Description
    T

    Min()

    Time complexity: O(log(n))

    Declaration
    public T Min()
    Returns
    Type Description
    T

    NextHigher(T)

    Get the next higher to given value in this BST.

    Declaration
    public T NextHigher(T value)
    Parameters
    Type Name Description
    T value
    Returns
    Type Description
    T

    NextLower(T)

    Get the next lower value to given value in this BST.

    Declaration
    public T NextLower(T value)
    Parameters
    Type Name Description
    T value
    Returns
    Type Description
    T

    Explicit Interface Implementations

    IEnumerable.GetEnumerator()

    Declaration
    IEnumerator IEnumerable.GetEnumerator()
    Returns
    Type Description
    IEnumerator

    Implements

    System.Collections.Generic.IEnumerable<T>
    System.Collections.IEnumerable
    Back to top Generated by DocFX