红黑树、HashSet集合、Map集合、HashMap集合、TreeMap集合

目录

红黑树

HashSet集合

Map集合

Map集合的遍历(方式1)

Map集合的遍历(方式2)

 HashMap集合

TreeMap集合


红黑树

红黑树的特点:

        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);

    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值