C#에서 레드-블랙 트리 알고리즘을 구현하는 방법

WBOY
풀어 주다: 2023-09-19 12:57:46
원래의
1412명이 탐색했습니다.

C#에서 레드-블랙 트리 알고리즘을 구현하는 방법

C#에서 레드-블랙 트리 알고리즘을 구현하려면 특정 코드 예제가 필요합니다.

소개:
레드-블랙 트리는 자체 균형 이진 검색 트리입니다. 유효한 레드-블랙 트리의 경우 가장 긴 경로가 가장 짧은 경로의 두 배를 넘지 않도록 특정 속성을 유지합니다. 이러한 특성으로 인해 레드-블랙 트리는 삽입, 삭제 및 검색 작업에서 더 나은 성능을 발휘합니다. 이 문서에서는 C#에서 레드-블랙 트리 알고리즘을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

레드-블랙 트리의 속성:
레드-블랙 트리에는 다음과 같은 5가지 속성이 있습니다.

  1. 각 노드는 빨간색 또는 검은색입니다.
  2. 루트 노드는 검은색입니다.
  3. 각 리프 노드(NIL 노드, 빈 노드)는 검정색입니다.
  4. 노드가 빨간색이면 해당 하위 노드는 모두 검은색입니다.
  5. 각 노드에 대해 해당 노드에서 모든 하위 리프 노드까지의 단순 경로에는 동일한 수의 블랙 노드가 포함됩니다.

레드-블랙 트리 구현:
다음은 C#에서 레드-블랙 트리를 구현하는 샘플 코드입니다.

enum Color
{
    Red,
    Black
}

class Node
{
    public int key;
    public Node parent;
    public Node left;
    public Node right;
    public Color color;

    public Node(int key)
    {
        this.key = key;
        color = Color.Black;
    }
}

class RedBlackTree
{
    private Node root;

    private void Insert(Node newNode)
    {
        Node current = root;
        Node parent = null;

        while (current != null)
        {
            parent = current;

            if (newNode.key < current.key)
                current = current.left;
            else
                current = current.right;
        }

        newNode.parent = parent;

        if (parent == null)
            root = newNode;
        else if (newNode.key < parent.key)
            parent.left = newNode;
        else
            parent.right = newNode;

        newNode.color = Color.Red;

        FixAfterInsertion(newNode);
    }

    private void FixAfterInsertion(Node newNode)
    {
        while (newNode != root && newNode.parent.color == Color.Red)
        {
            if (newNode.parent == newNode.parent.parent.left)
            {
                Node uncle = newNode.parent.parent.right;

                if (uncle != null && uncle.color == Color.Red)
                {
                    newNode.parent.color = Color.Black;
                    uncle.color = Color.Black;
                    newNode.parent.parent.color = Color.Red;
                    newNode = newNode.parent.parent;
                }
                else
                {
                    if (newNode == newNode.parent.right)
                    {
                        newNode = newNode.parent;
                        RotateLeft(newNode);
                    }

                    newNode.parent.color = Color.Black;
                    newNode.parent.parent.color = Color.Red;
                    RotateRight(newNode.parent.parent);
                }
            }
            else
            {
                Node uncle = newNode.parent.parent.left;

                if (uncle != null && uncle.color == Color.Red)
                {
                    newNode.parent.color = Color.Black;
                    uncle.color = Color.Black;
                    newNode.parent.parent.color = Color.Red;
                    newNode = newNode.parent.parent;
                }
                else
                {
                    if (newNode == newNode.parent.left)
                    {
                        newNode = newNode.parent;
                        RotateRight(newNode);
                    }

                    newNode.parent.color = Color.Black;
                    newNode.parent.parent.color = Color.Red;
                    RotateLeft(newNode.parent.parent);
                }
            }
        }

        root.color = Color.Black;
    }

    private void RotateLeft(Node node)
    {
        Node right = node.right;
        node.right = right.left;

        if (right.left != null)
            right.left.parent = node;

        right.parent = node.parent;

        if (node.parent == null)
            root = right;
        else if (node == node.parent.left)
            node.parent.left = right;
        else
            node.parent.right = right;

        right.left = node;
        node.parent = right;
    }

    private void RotateRight(Node node)
    {
        Node left = node.left;
        node.left = left.right;

        if (left.right != null)
            left.right.parent = node;

        left.parent = node.parent;

        if (node.parent == null)
            root = left;
        else if (node == node.parent.right)
            node.parent.right = left;
        else
            node.parent.left = left;

        left.right = node;
        node.parent = left;
    }

    // 其他方法:查找、删除等
    // ...

}
로그인 후 복사

요약:
이 문서에서는 C#에서 레드-블랙 트리 알고리즘을 구현하는 방법을 소개하고 자세한 코드를 제공합니다. 예. 레드-블랙 트리는 삽입, 삭제 및 검색 작업에서 더 나은 성능을 제공하는 자체 균형 이진 검색 트리입니다. 레드-블랙 트리를 사용하면 몇 가지 일반적인 문제를 보다 효율적으로 해결할 수 있습니다. 실제 응용에서는 필요에 따라 레드-블랙 트리의 기능을 적절하게 조정하고 확장할 수 있습니다. 이 글이 여러분에게 도움이 되고 레드-블랙 트리에 대한 관심과 심층적인 연구를 촉발하길 바랍니다.

위 내용은 C#에서 레드-블랙 트리 알고리즘을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿