红黑树、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=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值