Java特殊数据结构-TreeSet
- TreeSet初步入门总结 https://www.cnblogs.com/yzssoft/p/7127894.html
- TreeSet自然排序与比较器排序精讲 https://blog.csdn.net/xiaofei__/article/details/53138681
- TreeSet概念以及遍历方法 https://www.cnblogs.com/Tony-cheen/p/5681831.html
- TreeSet是JAVA中集合的一种有序集合,它的作用是提供有序的Set集合。它继承于AbstractSet抽象类,实现了NavigableSet<E>,Cloneable,java.io.Serializable接口。
- 因为TreeSet继承了AbstractSet抽象类,所以它是一个set集合,可以被实例化,且具有set的属性和add、remove、get等方法。
- TreeSet是基于TreeMap实现的。TreeSet中的元素支持2种排序方式:自然排序和比较器排序。
- TreeSet的性能比HashSet差,简单比较:HashSet使用散列表进行存储,元素无序,元素允许为null。TreeSet是使用树结构来进行存储,元素按字符串顺序排序存储,元素不允许为null。
public class TreeSet<E> extends AbstractSet<E> implements NavigableSet<E>, Cloneable, java.io.Serializable{}
- a.自然顺序(Comparable)
- TreeSet类的add()方法中会把存入的对象提升为Comparable类型
- 调用对象的compareTo()方法和集合中的对象比较
- 根据compareTo()方法返回的结果进行存储
- b.比较器顺序(Comparator)
- 创建TreeSet的时候可以制定 一个Comparator
- 如果传入了Comparator的子类对象, 那么TreeSet就会按照比较器中的顺序排序
- add()方法内部会自动调用Comparator接口中compare()方法排序
- 调用的对象是compare方法的第一个参数,集合中的对象是compare方法的第二个参数
- c.两种方式的区别
- TreeSet构造函数什么都不传, 默认按照类中Comparable的顺序(没有就报错ClassCastException)
- TreeSet如果传入Comparator, 就优先按照Comparator
- TreeSet的遍历方式
for(Iterator iter = set.iterator(); iter.hasNext(); ) {
iter.next();
}
// 假设set是TreeSet对象
for(Iterator iter = set.descendingIterator(); iter.hasNext(); ) {
iter.next();
}
// 假设set是TreeSet对象,并且set中元素是String类型
String[] arr = (String[])set.toArray(new String[0]);
for (String str:arr)
System.out.printf("for each : %s\n", str);
TreeSet 的构造函数
|
序号
|
构造函数的说明
|
|
1
|
TreeSet ()
此构造函数构造空树集,将在根据其元素的自然顺序按升序排序。
|
|
2
|
TreeSet (集合 c)
此构造函数生成树的集合,它包含的元素的集合 c。
|
|
3
|
TreeSet (比较器 comp)
此构造函数构造一个空树集,将根据给定的比较器进行排序。
|
|
4
|
TreeSet (SortedSet ss)
此构造函数生成包含给定 SortedSet 的元素 TreeSet
|
TreeSet的方法总结
|
修饰符和类型
|
方法和描述
|
|
boolean
|
add(E e)
将指定的元素添加到这套,如果它已不存在。
|
|
boolean
|
addAll(Collection<? extends E> c)
在加入这一组指定的集合中添加的所有元素。
|
|
E
|
ceiling(E e)
返回最小的元素在这一组大于或等于给定的元素,则null如果没有这样的元素。
|
|
void
|
clear()
从这一组中移除所有元素。
|
|
Object
|
clone()
返回此TreeSet实例浅表副本。
|
|
Comparator<? super E>
|
comparator()
返回用于排序在这集,或空元素,如果这套使用自然排序其元素的比较。
|
|
boolean
|
contains(Object o)
如果此集合包含指定的元素,则返回true 。
|
|
Iterator<E>
|
descendingIterator()
返回迭代器中这套降序排序的元素。
|
|
NavigableSet<E>
|
descendingSet()
返回逆序视图中包含的元素这一套。
|
|
E
|
first()
返回第一个 (最低) 元素当前在这一套。
|
|
E
|
floor(E e)
返回的最大元素在这一组小于或等于null如果没有这样的元素。
|
|
SortedSet<E>
|
headSet(E toElement)
返回其元素是严格小于toElement这套的部分视图.
|
|
NavigableSet<E>
|
headSet(E toElement, boolean inclusive)
返回一个视图的这部分设置的元素都小于 (或等于,如果inclusive是真的) toElement.
|
|
E
|
higher(E e)
返回最小的元素在这套严格大于给定的元素,则null如果没有这样的元素。
|
|
boolean
|
isEmpty()
如果此集不包含任何元素,则返回true 。
|
|
Iterator<E>
|
iterator()
返回迭代器中这套以升序排序的元素。
|
|
E
|
last()
在这套目前返回的最后一个 (最高) 的元素。
|
|
E
|
lower(E e)
在这一套严格的小于给定的元素,则null返回的最大元素,如果没有这样的元素。
|
|
E
|
pollFirst()
检索和删除第一个 (最低) 元素,或如果此集合为空,则返回null 。
|
|
E
|
pollLast()
检索和删除的最后一个 (最高) 的元素,或如果此集合为空,则返回null 。
|
|
boolean
|
remove(Object o)
从这一组中移除指定的元素,如果它存在。
|
|
int
|
size()
在这套 (其基数) 中返回的元素的数目。
|
|
NavigableSet<E>
|
subSet(E fromElement, boolean fromInclusive, E toElement, boolean toInclusive)
返回此集的部分视图的元素范围从fromElement到toElement.
|
|
SortedSet<E>
|
subSet(E fromElement, E toElement)
返回视图的部分的这一套的元素范围从fromElement,具有包容性,到toElement,独家。
|
|
SortedSet<E>
|
tailSet(E fromElement)
返回其元素是大于或等于fromElement这套的部分视图.
|
|
NavigableSet<E>
|
tailSet(E fromElement, boolean inclusive)
返回其元素是大于 (或等于,如果inclusive是真的) 这套的部分视图fromElement.
|
Java特殊数据结构-TreeSet的更多相关文章
- JAVA常用数据结构及原理分析
JAVA常用数据结构及原理分析 http://www.2cto.com/kf/201506/412305.html 前不久面试官让我说一下怎么理解java数据结构框架,之前也看过部分源码,balaba ...
- (6)Java数据结构-- 转:JAVA常用数据结构及原理分析
JAVA常用数据结构及原理分析 http://www.2cto.com/kf/201506/412305.html 前不久面试官让我说一下怎么理解java数据结构框架,之前也看过部分源码,balab ...
- 【转】Java学习---Java核心数据结构(List,Map,Set)使用技巧与优化
[原文]https://www.toutiao.com/i6594587397101453827/ Java核心数据结构(List,Map,Set)使用技巧与优化 JDK提供了一组主要的数据结构实现, ...
- Java HashSet和TreeSet【笔记】
Java HashSet和TreeSet[笔记] PS:HashSet.TreeSet 两个类是在 Map 的基础上组装起来的类 HashSet 类注释 1.底层实现基于 HashMap,所以迭代时不 ...
- java项目——数据结构实验报告
java项目——数据结构总结报告 20135315 宋宸宁 实验要求 1.用java语言实现数据结构中的线性表.哈希表.树.图.队列.堆栈.排序查找算法的类. 2.设计集合框架,使用泛型实现各类. ...
- Java深入了解TreeSet
Java中的TreeSet是Set的一个子类,TreeSet集合是用来对象元素进行排序的,同样他也可以保证元素的唯一.那TreeSet为什么能保证元素唯一,它是怎样排序的呢?先看一段代码: publi ...
- 【转载】图解Java常用数据结构(一)
图解Java常用数据结构(一) 作者:大道方圆 原文:https://www.cnblogs.com/xdecode/p/9321848.html 最近在整理数据结构方面的知识, 系统化看了下Jav ...
- java实现 数据结构:链表、 栈、 队列、优先级队列、哈希表
java实现 数据结构:链表. 栈. 队列.优先级队列.哈希表 数据结构javavector工作importlist 最近在准备找工作的事情,就复习了一下java.翻了一下书和网上的教材,发现虽然 ...
- Java同步数据结构之ConcurrentSkipListMap/ConcurrentSkipListSet
引言 上一篇Java同步数据结构之Map概述及ConcurrentSkipListMap原理已经将ConcurrentSkipListMap的原理大致搞清楚了,它是一种有序的能够实现高效插入,删除,更 ...
随机推荐
- PXE批量部署安装Linux系统
PXE介绍 1)Preboot Excution Environment 预启动执行环境 2)Intel公司研发 3)基于Client/Server的网络模式,支持远程主机通过网络从远端服务器下载映 ...
- Web应用特性
什么是web应用? 软件开发架构 c/s架构 客户端 服务端 b/s架构 浏览器 服务器 本质:b/s架构其实也是c/s架构 HTTP协议 超文本传输协议:规定了客户端与服务端消息传输的格式 四大特性 ...
- idou老师教你学Istio05: 如何用Isito实现智能路由配置
要介绍istio请求路由,我们不由得先从pilot 和 envoy开始谈起. 在服务网格中,Pilot管理和配置所有的envoy实例.在pilot中,你几乎可以配置所有的关于流量导向规则及其他故障恢复 ...
- JDBC连接数据库报错:Loading class `com.mysql.jdbc.Driver'. This is deprecated.
使用JDBC连接数据库时出现报错, 报错内容:Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver cla ...
- vsftpd的安装和配置
1 安装vsftpd sudo apt-get install vsftpd 2 测试是否安装成功 sudo service vsftpd restart 如果有反应即成功 3 彻底卸载vsft ...
- 接口调用实现类&& 为什么Autowired定义在接口上
1.接口与回调 package edu.cqu.interfaceTest; import java.awt.Toolkit; import java.awt.event.ActionEvent; i ...
- 在laravel5.8中集成swoole组件----用协程实现的服务端和客户端(二)---静态文件如何部署
目前,较为成熟的技术是采用laravelS组件,注意和laravel 区别laravelS多了一个大写的S,由于laravelS默认监听5200端口,所以laravel项目要做一些调整 例如: 静态文 ...
- windows下C语言头文件的运用
头文件 singnext.dingswords printf("终止我每丝呼吸,让心灵穿透所有的秘密\n"); 头文件 singtocj.h printf("当无数的日月 ...
- BZOJ 3551/3545: [ONTAK2010]Peaks加强版 (Kruskal树+dfs序上的主席树+倍增)
Orz PoPoQQQ 学到了维护子树信息的时候用dfsdfsdfs序套主席树节省线段树空间. 学到了怎么用指针写可持久化线段树-emmm- CODE 只贴上3551加强版带强制在线的代码 #incl ...
- BZOJ 3630: [JLOI2014]镜面通道 (网络流 +计算几何)
水能流过的地方光都能达到 呵呵.jpg 那就是裸的最小割(割开上边界和下边界)了- 判矩形和圆相交的时候就用圆心对矩形求一次点到矩形的最近距离(类似KD树的预估函数). CODE #include & ...