目录
红黑树
红黑树的特点:
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=").append(math);
sb.append(", english=").append(english);
//总成绩和也加进去
sb.append(", sum=").append(getSum());
sb.append('}');
return sb.toString();
}
@Override
public int compareTo(Student o) {
// 主要条件: 按照总分进行排序
int result = o.getSum() - this.getSum();
// 次要条件: 如果总分一样,就按照语文成绩排序
result = result == 0 ? o.getChinese() - this.getChinese() : result;
// 如果语文成绩也一样,就按照数学成绩排序
result = result == 0 ? o.getMath() - this.getMath() : result;
// 如果总分一样,各科成绩也都一样,就按照姓名排序
result = result == 0 ? o.getName().compareTo(this.getName()) : result;
return result;
}
}
//测试类
public class TreeSetDemo {
public static void main(String[] args) {
//创建TreeSet集合对象,通过比较器排序进行排序
TreeSet<Student> ts = new TreeSet<Student>();
//创建学生对象
Student s1 = new Student("jack", 98, 100, 95);
Student s2 = new Student("rose", 95, 95, 95);
Student s3 = new Student("sam", 100, 93, 98);
//把学生对象添加到集合
ts.add(s1);
ts.add(s2);
ts.add(s3);