Java Set集合之Treeset
来源:互联网 发布:linux查看swap大小 编辑:程序博客网 时间:2024/05/11 20:21
TreeSet它可以给Set集合中的元素进行指定方式的排序。
保证元素唯一性的方式:通过比较的结果是否为0.
这时可以让集合自身具备比较性。
控制台结果:由于排序条件为:年龄小的优先,年龄一样再按照名称排序最终结果如下:
模拟数据:构造TreeSet时传入实现了Comparator的类,此时People类中的compareTo方法已经不起作用,上面的代码是新的插入排序规则:
保证元素唯一性的方式:通过比较的结果是否为0.
底层数据结构是:二叉树。
让元素自身具备比较性。只要让元素实现Comparable接口,覆盖compareTo方法即可。
但是,如果元素自身不具备比较性,或者元素自身具备的比较性,不是所需要的。
比如,人的自然排序是按年龄排序,现在想要按照人的姓名排序。还可以不改动原有代码,此时可用第二种排列方式
这时可以让集合自身具备比较性。
可以定义一个类实现Comparator接口,覆盖compare方法。将该Comparator接口子类对象作为实际参数传递给TreeSet集合构造函数。该对象就是比较器。
以下例子使用到了泛型,
第一种排列方式例子:People类实现的comparable接口具备了比较性,具体的排序规则是通过compareTo方法实现的
/** * Comparable接口,使得People本身具备比较性,具体如何排序通过重写{@link People#compareTo(People)} 实现排序 * * @author TOO-YOUNG-TOO-SIMPLE */class People implements Comparable<People> {People(String name, int age) {this.name = name;this.age = age;}private String name;private int age;public String getName() {return name;}public int getAge() {return age;}/** * @return 0:表示重复元素 */@Overridepublic int compareTo(People o) {if (this.age == o.age) {// 年龄为排序首要条件,年龄相同下判断名字return this.name.compareTo(o.name);}return this.age - o.age;}@Overridepublic String toString() {return "People [name=" + name + ", age=" + age + "]";}}模拟添加数据:
public static void main(String[] args) {TreeSet<People> people = new TreeSet<People>();people.add(new People("tree3", 11));people.add(new People("tree1", 12));people.add(new People("tree2", 11));people.add(new People("tree2", 15));Iterator<People> p = people.iterator();while (p.hasNext()) {System.out.println(p.next().toString());}}
控制台结果:由于排序条件为:年龄小的优先,年龄一样再按照名称排序最终结果如下:
第二种排列方式例子:People类不管是否实现comparable接,即不管本身是否具备比较性,只要实例化TreeSet时实现Comparator接口,并重写compare方法,则最终排序将以compare方法中的规则排序,换句话说Comparator的优先级别高于Comparable,此时如果元素(People)实现了Comparable接口,其抽象方法compareTo将被覆盖.
/** * 实现Comparator接口重写{@link MyComp#compare(People, People)}方法实现排序规则 * * @author Administrator * */class MyComp implements Comparator<People> {/** * @return 0:表示元素存在,大于0表示按插入顺序排序,小于0表示插入到上个元素前 */@Overridepublic int compare(People o1, People o2) {if (o1.getName().compareTo(o2.getName()) == 0) {// 首先判断名字是否相同,相同再判断年龄是否相同return o1.getAge() - o2.getAge();}return o1.getName().compareTo(o2.getName());}}
模拟数据:构造TreeSet时传入实现了Comparator的类,此时People类中的compareTo方法已经不起作用,上面的代码是新的插入排序规则:
最终输出的结果如下:按照名字优先进行排序,名字相同再按照年龄排序
0 0
- Java Set集合之Treeset
- Java---28---Set集合之TreeSet
- 小东吖 之 java Set接口 HashSet集合 TreeSet集合
- Java集合框架-Set(TreeSet)
- Java基础--集合Set-TreeSet
- Java--集合(Set:HashSet,TreeSet)
- JAVA提高教程(4)-认识Set集合之TreeSet
- 黑马程序员:Java基础——Set集合之TreeSet
- Java集合框架复习之规则集Set-TreeSet(五)
- java集合类(七)Set之LinkedHashSet&TreeSet
- java集合框架之Set------02_02 TreeSet
- 【Java集合之Set】HashSet、TreeSet、LinkedHashSet区别
- Java常见集合框架(十):Set之TreeSet、HashSet
- Java集合之四Set、HashSet、LinkedHashSet、TreeSet
- Java集合之TreeSet
- java集合之TreeSet
- Java集合之TreeSet
- Java集合之TreeSet
- java.util.NoSuchElementException
- 教你怎么看一个网站是否存在漏洞!
- ArcSDE for Oracle在大数据量执行创建统计信息(Analyze)耗时长的问题
- byte类型取值范围以及溢出详解
- LeetCode | Copy List with Random Pointer(赋值带有随机指针的链表)
- Java Set集合之Treeset
- OGEngine:Java开发者的手游开发引擎
- CodeForces 383C
- 自比毕加索,揭秘神秘的“苹果大学”
- java.util.vector中的vector的详细用法
- 斐波拉切字符串统计个数 Fibonacci String
- Use Archive Utility preferences for control over archives
- jqGrid中rowNum关于返回值的设定
- jQuery 取值、赋值的基本方法整理