Java中TreeSet保证元素唯一且有序的原因

导读:本篇文章讲解 Java中TreeSet保证元素唯一且有序的原因,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

TreeSet底层数据结构

TreeSet底层依赖于TreeMap,TreeMap的数据结构是二叉树(红黑树),由底层数据结构决定了TreeSet中元素有序且唯一。

TreeSet集合中数据存储

使用二叉树存储数据

//第一次存储数据没有树根,就创建一个树根,把这个元素赋值给树根;
//第二次进行存储的时候,首先和根节点的元素进行比较,比较有三种情况:
  //第一种情况当前元素和根节点的元素相同,这是忽略该值,不存储该值;
  //第二种情况当前元素和根节点的元素相比,小于根节点元素,那么将该元素放在根节点的左边
  //第三种情况当前元素和根节点的元素相比,大于根节点元素,那么将该元素放在根节点的右边

举例:
存储下列元素: 20,18,23,22,17,24,19,18,24

		treeSet.add(20);
		treeSet.add(18);
		treeSet.add(23);
		treeSet.add(22);
		treeSet.add(17);
		treeSet.add(24);
		treeSet.add(19);
		treeSet.add(18);
		treeSet.add(24);

在这里插入图片描述从上图可以看出,相同的元素18,24并没有存进集合中,并且存进去的元素 已经从小到大排好了序,所以TreeSet保证了元素的唯一以及有序。

public class MyTest {
    public static void main(String[] args) {
        TreeSet<Integer> treeSet = new TreeSet<>();
        treeSet.add(20);
        treeSet.add(18);
        treeSet.add(23);
        treeSet.add(22);
        treeSet.add(17);
        treeSet.add(24);
        treeSet.add(19);
        treeSet.add(18);
        treeSet.add(24);
        System.out.println(treeSet);
    }
}
        //运行结果
        //[17, 18, 19, 20, 22, 23, 24]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/14647.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!