红黑树简单认识

红黑树是一种兼顾二叉查找树特性和平衡树优势的数据结构,通过节点颜色来保持平衡。主要特点包括节点的红色或黑色,以及特定的平衡规则。插入和删除操作可能导致不平衡,通过左旋、右旋和颜色反转来调整。深入理解可通过实际操作或在线工具进行学习。
摘要由CSDN通过智能技术生成

红黑树

红黑树首先是一种树形结构,同时又是一个二叉树(每个节点最多只能有两个孩子节点,左节点小于等于父节点,右节点大于父节点),为了保证树的左右孩子树相对平衡(深度相同),红黑树使用了节点标色的方式,将节点标记为红色或者黑色,在计算树的深度时只统计黑色节点的数量,不统计红色节点数量,同时没有变量高度,增加了父亲节点、叔叔节点颜色变量等。

主要特点(规则)

在这里插入图片描述
在进行插入和删除时有可能会触发红黑树的插入平衡调整(balanceInsertion方法)或删除平衡调整(balanceDeletion )方法,调整的方式主要有以下手段:左旋转(rotateLeft方法)、右旋转(rotateRight方法)、颜色反转,进行调整的原因是为了维持红黑树的数据结构。

代码实现

声明变量

package edu.xalead.tree.redTree;

import com.sun.org.apache.regexp.internal.RE;
import sun.reflect.generics.tree.Tree;

public class TreeNode {
    public static Boolean BLACK = false;//黑色
    public static Boolean RED = true;//红色
    private Object data = null;
    private TreeNode left = null;
    private TreeNode right = null;
    private Boolean color = RED;
    private TreeNode parent;


    public TreeNode getParent() {
        return parent;
    }

    public void setParent(TreeNode parent) {
        this.parent = parent;
    }

    public Boolean getColor() {
        return color;
    }

    public void setColor(Boolean color) {
        this.color = color;
    }

    public TreeNode(Object data) {
        this.data = data;
    }

    public Object getData() {
        return data;
    }

    public void setData(Object data) {
        this.data = data;
    }

    public TreeNode getLeft() {
        return left;
    }

    public void setLeft(TreeNode left) {
        this.left = left;
    }

    public TreeNode getRight() {
        return right;
    }

    public void setRight(TreeNode right) {
        this.right = right;
    }
}
添加数字所需要的接口

package edu.xalead.tree.redTree;

public interface
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值