03-使用一个不可变对象作为key,红黑树怎么比较大小?

使用一个不可变对象作为key,红黑树怎么比较大小?

答:Java 中的红黑树是通过左旋、右旋的方式来维护树的平衡性,而左旋、右旋又依赖于节点大小的比较。对于使用不可变对象作为key实际上是可以的,因为比较key的大小本身不依赖于key是否可变性,而是依赖于key实现的比较大小的方法。

作为红黑树中的key有如下几个条件

  • key必须是对象,不能是基本数据类型(如 int、double等,对应的包装类是可以的);
  • 作为key的该对象必须要实现Comparable接口,并重写compareTo方法,用于比较对象的顺序。compareTo方法返回值是一个整数,如果当前对象小于参数对象,应返回负整数;如果当前对象大于参数对象,应返回正整数;如果两个对象相等,应返回0。

使用红黑树实现排序的案例

java 复制代码
import java.util.Comparator;
import java.util.TreeSet;

class Person implements Comparable<Person> {
    private final String name;
    private final int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }

    @Override
    public int compareTo(Person other) {
        // 先按照姓名比较
        int nameComparison = this.name.compareTo(other.name);
        if (nameComparison != 0) {
            return nameComparison;
        }

        // 若姓名相同,则按照年龄比较
        return Integer.compare(this.age, other.age);
    }
}

public class RedBlackTreeExample {
    public static void main(String[] args) {
        // 创建红黑树,并添加元素
        TreeSet<Person> treeSet = new TreeSet<>();
        treeSet.add(new Person("Alice", 25));
        treeSet.add(new Person("Bob", 30));
        treeSet.add(new Person("Charlie", 20));
        treeSet.add(new Person("Alice", 30));

        // 遍历红黑树
        for (Person person : treeSet) {
            System.out.println(person.getName() + ", " + person.getAge());
        }
    }
}

知识扩展

(1)红黑树的插入和查找操作是如何利用键的比较结果来维护树的有序性的?

红黑树通过键的比较结果来维护树的有序性。在插入和查找操作中,红黑树根据键的比较结果来确定节点的位置,以保持树的有序性。

插入操作:

  1. 从根节点开始,将要插入的节点与当前节点进行键的比较。如果要插入的节点的键小于当前节点的键,则继续在当前节点的左子树中继续比较;如果要插入的节点的键大于当前节点的键,则继续在当前节点的右子树中继续比较。
  2. 重复上述步骤,直到找到一个空位置,将要插入的节点放入该位置。
  3. 插入节点后,通过旋转和重新着色操作,确保红黑树的性质得到恢复和维护。这些操作旨在保持红黑树的平衡性和有序性。

查询操作:

  1. 从根节点开始,将要查找的键与当前节点进行比较。如果要查找的键等于当前节点的键,则返回当前节点。
  2. 如果要查找的键小于当前节点的键,则继续在当前节点的左子树中继续比较。
  3. 如果要查找的键大于当前节点的键,则继续在当前节点的右子树中继续比较。
  4. 重复上述步骤,直到找到等于要查找键的节点或者遍历到叶子节点为止。如果遍历到叶子节点仍未找到匹配的节点,则表示键不存在于红黑树中。
相关推荐
i***39588 小时前
Springboot中SLF4J详解
java·spring boot·后端
z***94848 小时前
springboot和springframework版本依赖关系
java·spring boot·后端
p***95008 小时前
spring Profile
java·数据库·spring
艺杯羹8 小时前
从Spring到SpringBoot3的演进:缺陷、优化与最新实践要求
java·spring boot·spring
vir028 小时前
密码脱落(最长回文子序列)
数据结构·c++·算法
一 乐8 小时前
宠物管理宠物医院管理|基于Java+vue的宠物医院管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·宠物
一 乐8 小时前
学习辅导系统|数学辅导小程序|基于java+小程序的数学辅导小程序设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·学习·小程序
励志成为糕手8 小时前
基于SpringBoot的企业考勤管理系统设计与实现
java·spring boot·后端·web·企业应用
福尔摩斯张9 小时前
二维数组详解:定义、初始化与实战
linux·开发语言·数据结构·c++·算法·排序算法
e***74959 小时前
SpringBoot项目集成ONLYOFFICE
java·spring boot·后端