【Java】set 集合基础

简介: 1. set2. set 集合框架结构3. set 常用方法4. HashSet4.1 HashSet 的特点5. Set相关题目

1. set

set 继承于 Collection 接口,是一个不允许出现重复元素,且无序的集合,主要有 HashSet 和 TreeSet 两大实现类


在判断重复元素的时候,Set 集合汇调用 hashCode() 和 equals() 方法来实现


HashSet 是哈希表结构,主要利用 HashMap 的 key 来存储元素,计算插入元素的 hashCode 来获取元素在集合中的位置


TreeSet 是树结构,每一个元素都是树中的一个节点,插入的元素都会进行排序


2. set 集合框架结构

1683880351038.png


3. set 常用方法

与 List 接口一样, Set 接口也提供了对集合操作的基本方法

但不同的是,set 还提供了 equals() 和 hashCode() ,供其子类重写

public interface Set<E> extends Collection<E> {
    // 添加功能
    // 当添加元素在集合中已经存在时,会返回"false"
    boolean add(E e);
    boolean addAll(Collection<? extends E> c);
    // 删除功能
    boolean remove(Object o);
    boolean removeAll(Collection<?> c);
    void clear();
    // 长度功能
    int size();
    // 判断功能
    boolean isEmpty();
    boolean contains(Object o);
    boolean containsAll(Collection<?> c);
    boolean retainAll(Collection<?> c); 
    // 获取Set集合的迭代器:
    Iterator<E> iterator();
    // 把集合转换成数组
    Object[] toArray();
    <T> T[] toArray(T[] a);
    // 判断元素是否重复,为子类提供重写方法
    boolean equals(Object o);
    int hashCode();
}

4. HashSet

HashSet 实现set接口, 底层由HashMap来实现, 为哈希表结构,新增元素相当于HashMap的key,value默认为一个固定的Object。

当有元素插入的时候,会计算元素的hashCode值,将元素插入到哈希表对应的位置中来


4.1 HashSet 的特点

  • 不允许出现重复元素
  • 允许插入Null值
  • 元素无序


5. Set相关题目

剑指 Offer 03. 数组中重复的数字

67.png


本题目利用set元素不重复的原则,当一个元素在set中已经存在,第二次add时就会返回false,我们就可知道重复的元素


class Solution {
    public int findRepeatNumber(int[] nums) {
        Set<Integer> set = new HashSet<>();
        int tmp = -1;
        for (int num : nums) {
            if (!set.add(num)) {
                tmp = num;
                break;
            }
        }
        return tmp;
    }
}
目录
相关文章
|
22天前
|
安全 Java 容器
【Java集合类面试二十七】、谈谈CopyOnWriteArrayList的原理
CopyOnWriteArrayList是一种线程安全的ArrayList,通过在写操作时复制新数组来保证线程安全,适用于读多写少的场景,但可能因内存占用和无法保证实时性而有性能问题。
|
22天前
|
存储 安全 Java
【Java集合类面试二十五】、有哪些线程安全的List?
线程安全的List包括Vector、Collections.SynchronizedList和CopyOnWriteArrayList,其中CopyOnWriteArrayList通过复制底层数组实现写操作,提供了最优的线程安全性能。
|
22天前
|
Java
【Java集合类面试二十八】、说一说TreeSet和HashSet的区别
HashSet基于哈希表实现,无序且可以有一个null元素;TreeSet基于红黑树实现,支持排序,不允许null元素。
|
22天前
|
Java
【Java集合类面试二十三】、List和Set有什么区别?
List和Set的主要区别在于List是一个有序且允许元素重复的集合,而Set是一个无序且元素不重复的集合。
|
22天前
|
Java
【Java集合类面试二十六】、介绍一下ArrayList的数据结构?
ArrayList是基于可动态扩展的数组实现的,支持快速随机访问,但在插入和删除操作时可能需要数组复制而性能较差。
|
22天前
|
存储 Java 索引
【Java集合类面试二十四】、ArrayList和LinkedList有什么区别?
ArrayList基于动态数组实现,支持快速随机访问;LinkedList基于双向链表实现,插入和删除操作更高效,但占用更多内存。
|
12天前
|
Java
用JAVA架建List集合为树形结构的代码方法
这段代码定义了一个表示树形结构的 `Node` 类和一个用于构建树形结构的 `TreeController`。`Node` 类包含基本属性如 `id`、`pid`、`name` 和 `type`,以及子节点列表 `children`。`TreeController` 包含初始化节点列表并将其转换为树形结构的方法。通过过滤和分组操作实现树形结构的构建。详情可见:[代码示例链接1](http://www.zidongmutanji.com/zsjx/43551.html),[代码效果参考链接2](https://www.257342.com/sitemap/post.html)。
25 5
|
13天前
|
索引 Python 容器
为什么Python中会有集合set类型?
为什么Python中会有集合set类型?
|
12天前
|
存储 Java 程序员
Java中的集合框架:从入门到精通
【8月更文挑战第30天】在Java的世界里,集合框架是一块基石,它不仅承载着数据的存储和操作,还体现了面向对象编程的精髓。本篇文章将带你遨游Java集合框架的海洋,从基础概念到高级应用,一步步揭示它的奥秘。你将学会如何选择合适的集合类型,掌握集合的遍历技巧,以及理解集合框架背后的设计哲学。让我们一起探索这个强大工具,解锁数据结构的新视角。
|
13天前
|
存储 算法 Java
Java中的集合框架深度解析云上守护:云计算与网络安全的协同进化
【8月更文挑战第29天】在Java的世界中,集合框架是数据结构的代言人。它不仅让数据存储变得优雅而高效,还为程序员提供了一套丰富的工具箱。本文将带你深入理解集合框架的设计哲学,探索其背后的原理,并分享一些实用的使用技巧。无论你是初学者还是资深开发者,这篇文章都将为你打开一扇通往高效编程的大门。