IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 自己写的Unity红黑树,简单明了。 -> 正文阅读

[游戏开发]自己写的Unity红黑树,简单明了。

红黑树是个强大的工具,方便定位。

算了不说了,直接上代码

public enum RedBlack
    {
        Red,
        Black,
    }
    public class RedBlackTree<T> where T : IComparable 
    {
        public class RedBlackTreeNode
        {
            public T Value;
            public RedBlack Color;
            public RedBlackTreeNode Left;
            public RedBlackTreeNode Right;
            public RedBlackTreeNode Parent;

            public RedBlackTreeNode(T value)
            {
                Value = value;
                Color = RedBlack.Red;
            }
            
            public RedBlackTreeNode(T value , RedBlackTreeNode parent)
            {
                Value = value;
                Parent = parent;
                Color = RedBlack.Red;
            }

            public RedBlackTreeNode GetAnotherSon(RedBlackTreeNode son)
            {
                if (son.Equals(Left))
                    return Right;
                return Left;
            }

            public RedBlackTreeNode Brother()
            {
                return Parent.GetAnotherSon(this);
            }

            public bool IsLeft(RedBlackTreeNode son)
            {
                return son.Equals(Left);
            }
            
            public bool IsParentLeft()
            {
                return Equals(Parent.Left);
            }
        }

        public RedBlackTreeNode Root;
        public int Size;
        
        public RedBlackTree()
        {
            Size = 0;
        }

        public IEnumerator<T> PreOrder(RedBlackTreeNode node)
        {
            if(node == null)
                yield break;
            yield return node.Value;
            PreOrder(node.Left);
            PreOrder(node.Right);
        }
        
        public IEnumerable<T> MidOrder(RedBlackTreeNode node)
        {
            if(node == null)
                yield break;
            MidOrder(node.Left);
            yield return node.Value;
            MidOrder(node.Right);
        }
        
        public IEnumerable<T> PostOrder(RedBlackTreeNode node)
        {
            if(node == null)
                yield break;
            PostOrder(node.Left);
            PostOrder(node.Right);
            yield return node.Value;
        }

        public T this[object obj]
        {
            get
            {
                return Find(obj);
            }
        }

        public void Inset(T value)
        {
            if (Root == null)
            {
                Root = new RedBlackTreeNode(value,null);
                Root.Color = RedBlack.Black;
                Size = 1;
                return;
            }

            Inset(Root, value);
        }

        public bool Contain(object value)
        {
            return Find(value).Equals(default);
        }

        public T Find(object value)
        {
            if (Root == null)
            {
                return default;
            }
            return Find(Root, value);
        }

        T Find(RedBlackTreeNode node, object value)
        {
            int result = node.Value.CompareTo(value);
            if (result == 0)
                return node.Value;
            if (result < 0 && node.Right != null)
                return Find(node.Right, value);
            else if(result > 0 && node.Left != null)
                return Find(node.Left, value);
            return default;
        }

        //右旋转节点
        void RightRotate(RedBlackTreeNode node)
        {
            RedBlackTreeNode left = node.Left;
            
            node.Left = left.Right;
            if (left.Right != null)
                left.Right.Parent = node;

            if (node == Root)
                Root = left;
            else if (node.Parent.IsLeft(node))
                node.Parent.Left = left;
            else
                node.Parent.Right = left;

            left.Right = node;
            left.Parent = node.Parent;
            node.Parent = left;    
        }
        
        //左旋转节点
        void LeftRotate(RedBlackTreeNode node)
        {
            RedBlackTreeNode right = node.Right;
            
            node.Right = right.Left;
            if (right.Left != null)
                right.Left.Parent = node;

            if (node == Root)
                Root = right;
            else if (node.Parent.IsLeft(node))
                node.Parent.Left = right;
            else
                node.Parent.Right = right;

            right.Left = node;
            right.Parent = node.Parent;
            node.Parent = right;    
        }


        
        #region 插入节点
        
        void Inset(RedBlackTreeNode node ,T value)
        {
            int result = node.Value.CompareTo(value);
            if (result == 0)
            {
                node.Value = value;
                return;
            }

            if (result > 0)
            {
                if (node.Left == null)
                {
                    RedBlackTreeNode inset = new RedBlackTreeNode(value ,node);
                    node.Left = inset;
                    Size++;
                    CheckNode(inset);
                }
                else
                    Inset(node.Left,value);
            }
            else
            {
                if (node.Right == null)
                {
                    RedBlackTreeNode inset = new RedBlackTreeNode(value ,node);
                    node.Right = inset;
                    Size++;
                    CheckNode(inset);
                }
                else
                    Inset(node.Right,value);
            }
        }
        
        void CheckNode(RedBlackTreeNode node)
        {
            if (node.Equals(Root))
            {
                Root_Node(node);
                return;
            }

            if (node.Parent.Color == RedBlack.Black)
            {
                Parent_Is_Black(node);
                return;
            }

            if (node.Parent.Brother() != null && node.Parent.Brother().Color == RedBlack.Red)
            {
                Parent_Is_Red_Uncle_Is_Red(node);
                return;
            }

            if (node.Parent.IsParentLeft())
            {
                if (node.IsParentLeft())
                {
                    Parent_Is_RedLeft_The_Is_Left(node);
                }
                else
                {
                    Parent_Is_RedLeft_The_Is_Right(node);
                }
            }
            else
            {
                if (node.IsParentLeft())
                {
                    Parent_Is_RedRight_The_Is_Left(node);
                }
                else
                {
                    Parent_Is_RedRight_The_Is_Right(node);
                }
            }
                
        }

        void Root_Node(RedBlackTreeNode node)//插入结点是根结点
        {
            node.Color = RedBlack.Black;
        }

        void Parent_Is_Black(RedBlackTreeNode node) //父结点是黑色
        {
            ;
        }

        void Parent_Is_Red_Uncle_Is_Red(RedBlackTreeNode node) //父节点是红色,叔叔结点是红色
        {
            RedBlackTreeNode parent = node.Parent;
            parent.Color = RedBlack.Black;
            parent.Brother().Color = RedBlack.Black;
            parent.Parent.Color = RedBlack.Red;
            CheckNode(parent.Parent);
        }

        void Parent_Is_RedLeft_The_Is_Left(RedBlackTreeNode node) //父节点是红色在祖父结点左边,插入结点在父结点左边
        {
            RedBlackTreeNode parent = node.Parent;
            parent.Color = RedBlack.Black;
            parent.Parent.Color = RedBlack.Red;
            RightRotate(parent.Parent);
        }

        void Parent_Is_RedLeft_The_Is_Right(RedBlackTreeNode node) //父节点是红色在祖父结点左边,插入结点在父结点右边
        {
            RedBlackTreeNode parent = node.Parent;
            LeftRotate(parent);
            Parent_Is_RedLeft_The_Is_Left(parent);
        }

        void Parent_Is_RedRight_The_Is_Left(RedBlackTreeNode node) //父节点是红色在祖父结点右边,插入结点在父结点左边
        {
            RedBlackTreeNode parent = node.Parent;
            RightRotate(parent);
            Parent_Is_RedRight_The_Is_Right(parent);
        }

        void Parent_Is_RedRight_The_Is_Right(RedBlackTreeNode node) //父节点是红色在祖父结点右边,插入结点在父结点右边
        {
            RedBlackTreeNode parent = node.Parent;
            parent.Color = RedBlack.Black;
            parent.Parent.Color = RedBlack.Red;
            LeftRotate(parent.Parent);
        }
        #endregion
        
        
        
        #region 删除节点
        
        private RedBlackTreeNode _replaceNode;
        public bool Delete(T value)
        {
            if (Root.Value.CompareTo(value) == 0)
            {
                Root = null;
                return true;
            }

            return Delete(Root, value);
        }
        
        bool Delete(RedBlackTreeNode node ,T value)
        {
            if (node == null)
                return false;
            int result = node.Value.CompareTo(value);
            if (result == 0)
            {
                _replaceNode = node;
                Delete(node);
                return true;
            }
            else if (result <= 0)
            {
                return Delete(node.Right, value);
            }
            else
            {
                return Delete(node.Left, value);
            }
        }
        
        void Delete(RedBlackTreeNode node)
        {
            if (node.Left == null && node.Right == null)
            {
                _replaceNode.Value = node.Value;
                _replaceNode = null;
                DeleteCheckNode(node);
            }
            else if(node.Left != null && node.Right != null)
            {
                RedBlackTreeNode mostLeft = GetMostLeftNode(node.Right);
                _replaceNode.Value = node.Value;
                _replaceNode = node;
                Delete(mostLeft);
            }
            else if(node.Left != null)
            {
                RedBlackTreeNode left = node.Left;
                _replaceNode.Value = node.Value;
                _replaceNode = node;
                Delete(left);
            }
            else
            {
                RedBlackTreeNode right = node.Right;
                _replaceNode.Value = node.Value;
                _replaceNode = node;
                Delete(right);
            }
        }

        RedBlackTreeNode GetMostLeftNode(RedBlackTreeNode node)
        {
            if (node.Left == null)
                return node;
            return GetMostLeftNode(node.Left);
        }

        void DeleteCheckNode(RedBlackTreeNode node)
        {
            DeleteSubCheckNode(node);
            DeleteDirectly(node);
        }

        void DeleteSubCheckNode(RedBlackTreeNode node)
        {
            if (node.Color == RedBlack.Red)
            {
                Delete_Node_Is_Red(node);
                return;
            }

            if (node.IsParentLeft())
            {
                if (node.Brother().Color == RedBlack.Red)
                    Delete_The_Is_Left_Brother_Is_Red(node);
                else if (node.Brother().Right != null && node.Brother().Right.Color == RedBlack.Red)
                    Delete_The_Is_Left_BrotherRight_Is_Red(node);
                else if (node.Brother().Left != null && node.Brother().Left.Color == RedBlack.Red)
                    Delete_The_Is_Left_BrotherRight_Is_Black_BrotherLeft_Is_Red(node);
                else
                    Delete_The_Is_Left_BrotherLeftRight_Is_Black(node);
            }
            else
            {
                if (node.Brother().Color == RedBlack.Red)
                    Delete_The_Is_Right_Brother_Is_Red(node);
                else if (node.Brother().Left != null && node.Brother().Left.Color == RedBlack.Red)
                    Delete_The_Is_Right_BrotherLeft_Is_Red(node);
                else if (node.Brother().Right != null && node.Brother().Right.Color == RedBlack.Red)
                    Delete_The_Is_Right_BrotherLeft_Is_Black_BrotherRight_Is_Red(node);
                else
                    Delete_The_Is_Right_BrotherLeftRight_Is_Black(node);
            }
        }

        void DeleteDirectly(RedBlackTreeNode node)
        {
            if (node.Parent.IsLeft(node))
                node.Parent.Left = null;
            else
                node.Parent.Right = null;
            Size--;
            node = null;
        }

        void Delete_Node_Is_Red(RedBlackTreeNode node) //删除结点是红色结点
        {
            node.Color = RedBlack.Black;
        }

        
        //-----------------------左边
        void Delete_The_Is_Left_Brother_Is_Red(RedBlackTreeNode node) //删除结点是黑色结点,其兄弟节点是红色节点
        {
            RedBlackTreeNode brother = node.Brother();
            brother.Color = RedBlack.Black;
            node.Parent.Color = RedBlack.Red;
            LeftRotate(node.Parent);
            DeleteSubCheckNode(node);
        }
        
        void Delete_The_Is_Left_BrotherRight_Is_Red(RedBlackTreeNode node) //删除结点是黑色结点,其兄弟节点是黑色节点,兄弟节点右节点是红色
        {
            RedBlackTreeNode brother = node.Brother();
            brother.Color = node.Parent.Color;
            brother.Right.Color = RedBlack.Black;
            node.Parent.Color = RedBlack.Black;
            LeftRotate(node.Parent);
        }
        
        void Delete_The_Is_Left_BrotherRight_Is_Black_BrotherLeft_Is_Red(RedBlackTreeNode node)
        {
            RedBlackTreeNode brother = node.Brother();
            brother.Color = RedBlack.Red;
            brother.Left.Color = RedBlack.Black;
            RightRotate(brother);
            Delete_The_Is_Left_BrotherRight_Is_Red(node);
        }
        
        void Delete_The_Is_Left_BrotherLeftRight_Is_Black(RedBlackTreeNode node)
        {
            RedBlackTreeNode brother = node.Brother();
            brother.Color = RedBlack.Red;
            DeleteSubCheckNode(node.Parent);
        }
        
        //-----------------------右边
        
        void Delete_The_Is_Right_Brother_Is_Red(RedBlackTreeNode node) //删除结点是黑色结点,其兄弟节点是红色节点
        {
            RedBlackTreeNode brother = node.Brother();
            brother.Color = RedBlack.Black;
            node.Parent.Color = RedBlack.Red;
            RightRotate(node.Parent);
            DeleteSubCheckNode(node);
        }
        
        void Delete_The_Is_Right_BrotherLeft_Is_Red(RedBlackTreeNode node) //删除结点是黑色结点,其兄弟节点是黑色节点,兄弟节点右节点是红色
        {
            RedBlackTreeNode brother = node.Brother();
            brother.Color = node.Parent.Color;
            brother.Left.Color = RedBlack.Black;
            node.Parent.Color = RedBlack.Black;
            RightRotate(node.Parent);
        }
        
        void Delete_The_Is_Right_BrotherLeft_Is_Black_BrotherRight_Is_Red(RedBlackTreeNode node)
        {
            RedBlackTreeNode brother = node.Brother();
            brother.Color = RedBlack.Red;
            brother.Right.Color = RedBlack.Black;
            LeftRotate(brother);
            Delete_The_Is_Right_BrotherLeft_Is_Red(node);
        }
        
        void Delete_The_Is_Right_BrotherLeftRight_Is_Black(RedBlackTreeNode node)
        {
            RedBlackTreeNode brother = node.Brother();
            brother.Color = RedBlack.Red;
            DeleteSubCheckNode(node.Parent);
        }
        #endregion
    }

测试代码

public class Test1 :IComparable
    {
        public int Value;
        public int CompareTo(object obj)
        {
            if (obj is int)
            {
                if (Value == (int)obj)
                    return 0;
                else if (Value < (int)obj)
                    return -1;
                return 1;
            }
            else if (obj is Test1)
            {
                Test1 target = obj as Test1;
                if (Value == target.Value)
                    return 0;
                else if (Value < target.Value)
                    return -1;
                return 1;
            }
            throw new Exception("obj对象不是int也不是Test1");
        }

        public Test1(int value)
        {
            Value = value;
        }
        public override string ToString()
        {
            return Value.ToString();
        }
    }

测试代码

RedBlackTree<Test1> a = new RedBlackTree<Test1>();
        for (int i = 0; i < 100; i++)
        {
            a.Inset(new Test1(i));
        }
        
        for (int i = 10; i < 20; i++)
        {
            a.Delete(new Test1(i));
        }
        //前序遍历
        foreach(var b in a.PreOrder(a.Root))
        {
        
        }
        //中序遍历
        foreach(var b in a.MidOrder(a.Root))
        {
        
        }
        //后序遍历
        foreach(var b in a.PostOrder(a.Root))
        {
        
        }
  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2021-10-23 12:48:29  更:2021-10-23 12:49:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 4:40:08-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码