The TreeSet function in Java can be used to sort the collection. Unlike other sets, TreeSet sorts elements according to their natural ordering. The following will introduce in detail how to use the TreeSet function to sort the collection.
- TreeSet introduction
TreeSet is an ordered set based on red-black tree implementation. TreeSet inherits from the AbstractSet class and implements the NavigableSet interface. TreeSet implements natural ordering of elements or ordering by a passed Comparator object.
For TreeSet, the most important methods are add(), remove(), contains() and other methods. These methods are implemented by calling methods in the AbstractSet class. In addition, TreeSet also implements several ordered set methods such as first(), last(), headSet(), tailSet(), subSet(), etc.
- Use TreeSet to sort collections
The following will use an example to introduce how to use TreeSet to sort collections. We will use a Student class and create a collection of multiple Student objects to sort.
First, we need to define the Student class:
public class Student implements Comparable<Student> { private String name; private int age; public Student(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } @Override public int compareTo(Student student) { return this.age - student.age; } @Override public String toString() { return "Student{" + "name='" + name + ''' + ", age=" + age + '}'; } }
In the above code, we define a Student class and implement the Comparable interface. We define the natural ordering method of elements by implementing the compareTo() method.
When comparing two Student objects, we compare their ages because we want to sort students by age.
Next, we create a collection containing multiple Student objects:
Set<Student> students = new TreeSet<>(); students.add(new Student("张三", 20)); students.add(new Student("李四", 19)); students.add(new Student("王五", 22)); students.add(new Student("赵六", 21));
We can see that we added four Student objects to the collection. Instead of using the Collections.sort() method to sort the collection, we use the TreeSet function, which automatically sorts the elements according to their natural ordering.
Finally, we can use the for-each loop to traverse the collection and output the student's information:
for (Student student : students) { System.out.println(student); }
The final output results will be sorted according to the age of the students from small to large:
Student{name='李四', age=19} Student{name='张三', age=20} Student{name='赵六', age=21} Student{name='王五', age=22}
- Custom sorting method
If we don’t want to sort according to the natural ordering of elements, we can use the Comparator object to customize the sorting method. The following code demonstrates how to use a Comparator object to customize the sorting method:
Set<Student> students = new TreeSet<>(Comparator.comparing(Student::getName)); students.add(new Student("张三", 20)); students.add(new Student("李四", 19)); students.add(new Student("王五", 22)); students.add(new Student("赵六", 21));
In the above code, we passed in a Comparator object when creating the TreeSet object. We define the sorting method by calling the Comparator.comparing() method and using the getName() method in the Student class. This means we will sort by student name.
Finally, we still use the for-each loop to traverse the collection and output the student's information:
for (Student student : students) { System.out.println(student); }
The final output will be sorted by the student's name from small to large:
Student{name='李四', age=19} Student{name='张三', age=20} Student{name='赵六', age=21} Student{name='王五', age=22}
- Summary
Using the TreeSet function to sort a collection is simpler than other methods. It will automatically sort according to the natural ordering of elements, or you can customize the sorting method by passing in a Comparator object. By mastering the use of TreeSet, we can sort collections in Java more easily.
The above is the detailed content of How to use the TreeSet function to sort sets in Java. For more information, please follow other related articles on the PHP Chinese website!

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

封装是一种信息隐藏技术,是指一种将抽象性函式接口的实现细节部分包装、隐藏起来的方法;封装可以被认为是一个保护屏障,防止指定类的代码和数据被外部类定义的代码随机访问。封装可以通过关键字private,protected和public实现。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于平衡二叉树(AVL树)的相关知识,AVL树本质上是带了平衡功能的二叉查找树,下面一起来看一下,希望对大家有帮助。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

SublimeText3 Linux new version
SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

WebStorm Mac version
Useful JavaScript development tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft
