目录
红黑树
红黑树的特点:
1.平衡二叉B数
2.每一个节点可以是红或黑
3.红黑树不是高度平衡的,它的平衡是通过“自己的红黑规则”进行实现的
红黑树的规则:
1.每个节点是红色或者是黑色
2.根节点必须是黑色
3.如果一个节点没有子节点或者父节点,则节点相应的指针属性值为Nil,这些Nil视为叶节点,每个叶节点(Nil)是黑色的
4.如果某一个节点是红色,那么它的子节点必须是黑色(不能出现两个红色节点相连的情况)
5.对每一个节点,从该节点到其所有后代子节点的简单路径上,均包含相同数目的黑色节点
红黑树添加节点的默认颜色
-
添加节点时,默认为红色,效率高
红黑树添加节点后如何保持红黑规则:
根节点位置:直接变为黑色
非根节点位置:父节点为黑色
不需要任何操作,默认红色即可
父节点为红色
叔叔节点为红色
1.将“父节点”设为黑色,将“叔叔节点”设为黑色
2.将“父节点”设为红色
3.如果“祖父节点”为根节点,则将根节点再次变成黑色
叔叔节点为黑色
1.将“父节点”设为黑色
2.将“祖父节点”设为红色
3.以“祖父节点”为支点进行旋转
成绩排序案例
案例需求
用TreeSet集合存储多个学生信息(姓名,语文成绩,数学成绩,英语成绩),并遍历该集合
要求: 按照总分从高到低出现
代码实现
//自定义类
public class Student implements Comparable<Student> {
private String name;
private int chinese;
private int math;
private int english;
public Student() {
}
public Student(String name, int chinese, int math, int english) {
this.name = name;
this.chinese = chinese;
this.math = math;
this.english = english;
}
。。。get,set方法。。。
//提供getSum成员方法,计算总成绩和
public int getSum() {
return this.chinese + this.math + this.english;
}
//重写toString()方法
@Override
public String toString() {
final StringBuilder sb = new StringBuilder("Student{");
sb.append("name='").append(name).append('\'');
sb.append(", chinese=").append(chinese);
sb.append(", math=