Java.数据结构.TreeSet

一、什么是TreeSet?

TreeSet是Java集合框架中的一部分,是基于TreeMap实现的。TreeSet保证了集合中的元素按照自然顺序或者通过提供的Comparator进行排序。

二、TreeSet的特点
  1. 有序性:TreeSet会根据元素的自然顺序进行排序,确保集合中的元素总是处于有序状态,和TreeMap一样,我们同样可以通过重写Comparator方法来进行排序。,

  2. 唯一性:TreeSet中的元素是唯一的,不能重复。如果有两个元素相等,则后插入的元素不会出现在集合中。

  3. 效率:TreeSet基于TreeMap实现,其时间复杂度为O(log n)。

三、TreeSet的基本操作

1.添加元素 :使用add(E e)方法。

java 复制代码
TreeSet<Integer> set = new TreeSet<>();  
set.add(1);  
set.add(2);

2.删除元素 :使用remove(Object o)方法。

java 复制代码
set.remove(1); // 删除元素1

3.判断元素是否存在 :使用contains(Object o)方法。

java 复制代码
boolean contains = set.contains(2); // 返回true

4.遍历元素:使用for-each循环。

java 复制代码
for (Integer num : set) {  
    System.out.println(num);  
}
相关推荐
黎明smaly2 小时前
从零学编程-C语言-第17天
c语言·数据结构·c++·算法·visual studio
疑惑的杰瑞4 小时前
[数据结构]带头双向循环链表的实现与应用
c语言·数据结构·算法·链表
Liu_Junwei5 小时前
回溯算法解决排列组合及子集问题
数据结构·算法
黎明smaly6 小时前
【数据结构与算法初阶】前言介绍
c语言·开发语言·数据结构·算法
single5946 小时前
【优选算法】(第十八篇)
java·数据结构·c++·vscode·算法·leetcode
&梧桐树夏7 小时前
【算法系列-链表】链表相交 & 环形链表II
数据结构·算法·链表
程序garbage7 小时前
排队打水(贪心)
数据结构·算法
山顶风景独好8 小时前
【Leecode 随笔】C语言版看了不后悔系列持续更新中。。。
c语言·开发语言·数据结构·算法·leecode
CyberMuse11 小时前
传统流程图和N-S流程图的区别
数据结构