Java学习(93)Java集合排序——TreeSet的使用


TreeSet是一个有序的集合,它支持自然排序和根据实现Comparator或Comparable接口进行排序。下面我们通过案例来看一下TreeSet的使用。

1. 使用TreeSet对String类型的数据进行存储,存储顺序默认按字母升序排序。

first()last()
在本例题中,定义TreeSet集合,并添加多个字符串到集合中,然后对集合进行遍历输出,并通过first()和last()方法来获取集合的第一个和最后一个元素。


运行结果:


2. 使用TreeSet对Integer类型数据进行存储,存储顺序默认按数字从小到大排序。

floor()
在本例题中,定义TreeSet对象,并向集合中添加整型数据,然后输出集合对象,也就是将数据放到[]中输出,这是集合的默认输出格式。然后使用floor()方法获得集合中最大的元素小于或等于给定元素的值,并输出。
代码如下:


运行结果:


说明:
a. 关于floor()方法,对于IntSet.floor(10),集合中有等于10的元素,所以输出结果为10;对于IntSet.floor(2),集合中没有2,那么小于2的最大元素就是-1,所以输出结果为-1;对于IntSet.floor(-2),由于集合中没有小于等于-2的元素,所以输出结果为null。
b. 与floor()方法类似,TreeSet中还有一个higher()方法,用于返回杨哥大于给定元素的该集合中的最小元素,如果没有此元素则返回null。

3. 当TreeSet中添加自定义类的对象时,是如何进行排序的呢?

pollFirst()pollLast()
这里需要实现Comparator和Comparable接口指定以什么属性进行排序,以及是升序还是降序排序。
下面以Comparator接口为例,实现Person对象按年龄升序排序。

  1. 定义Person类,包括编号、姓名和年龄三个属性,以及构造方法,get和set方法,toString()方法等内容。下面代码省略了get和set方法,运行时可以补上。


  2. 定义PersonComparator类,实现年龄的升序排序


  3. 在测试类的主方法中,定义五个Person类的对象,并添加到TreeSet中,然后显示集合所有元素。并使用pollFirst()方法返回并删除集合第一个元素。


运行结果:


说明:
a. 注意创建TreeSet对象时,要指定Comparator接口的实现类作为参数


b. 这里使用了pollFirst()方法,该方法比较特殊,可以返回元素,但是又把这个元素删除了,所以再次循环输出就没有age为17的元素了。
c. 还有一个方法pollLast(),功能是检索并删除最后一个元素,如果集合为空,则返回null。该方法的使用方式与pollFirst()类似。
d. 如果对age进行降序排序,可以将PersonComparator类的如下选中代码改为:o2.getAge()-01.getAge()


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值