Java,定义一个类TestTreeSet,要求如下:(1)定义TreeSet对象treeSet,左边用接口Set右边用TreeSet;(2)依次添加“apple”,“pear”,“bannana”,“orange”;(3)打印输出treeSet;观察输出的字符串输出顺序(注释说明为什么是有序的?按照什么顺序排列的?)
时间: 2024-03-16 16:45:05 浏览: 58
好的,这是一个Java类的代码示例,满足你的要求:
```java
import java.util.Set;
import java.util.TreeSet;
public class TestTreeSet {
public static void main(String[] args) {
Set<String> treeSet = new TreeSet<String>();
treeSet.add("apple");
treeSet.add("pear");
treeSet.add("bannana");
treeSet.add("orange");
System.out.println("treeSet中元素为:");
for (String str : treeSet) {
System.out.println(str);
}
}
}
```
解释一下这段代码:
1. 首先定义了一个 `TestTreeSet` 类,并在该类中定义了一个 `main` 方法,用于测试程序的正确性。
2. 在 `main` 方法中,我们使用 `TreeSet` 类型的对象 `treeSet` 来存储字符串类型的元素,因为 `TreeSet` 是基于红黑树实现的,对于元素的插入、删除和查询操作都很高效。同时,由于 `TreeSet` 实现了 `SortedSet` 接口,所以它的元素是有序的。
3. 然后,我们依次向 `treeSet` 中添加了四个元素,分别是 "apple"、"pear"、"bannana"、"orange"。
4. 最后,我们使用 `foreach` 循环遍历 `treeSet`,并打印输出每一个元素。由于 `TreeSet` 是有序的,所以输出的字符串顺序是按照字典序排列的,即 "apple"、"bannana"、"orange"、"pear"。
因此,这里的排序是按照元素的自然顺序进行的,即按照字典序进行排序。如果需要按照自定义的顺序进行排序,可以使用 `TreeSet` 的构造方法来传入一个 `Comparator` 对象,用于自定义排序规则。
阅读全文