《恋上数据结构第1季》集合 ListSet、TreeSet、HashSet

简介: 《恋上数据结构第1季》集合 ListSet、TreeSet、HashSet
数据结构与算法笔记目录《恋上数据结构》 笔记目录

想加深 Java 基础推荐看这个Java 强化笔记目录

我的《恋上数据结构》源码(第1季 + 第2季):https://github.com/szluyu99/Data_Structure_Note

集合的特点:

  • 不存放重复的元素
  • 常用于去重
    存放新增 IP,统计新增 IP
    存放词汇,统计词汇量
    ...

思考:集合的内部实现能否直接利用以前学过的数据结构?

  • 动态数组
  • 链表
  • 二叉搜索树(AVL树、红黑树)

集合的接口定义

集合的接口文件(interface),所有实现的集合都需要实现该接口。

public interface Set<E> {
    int size();    //元素数量
    boolean isEmpty(); // 是否为空
    void claer(); // 清空集合
    boolean contains(E element); // 是否包含element元素
    void add(E element); // 添加element元素
    void remove(E element); // 删除element元素
    void traversal(Visitor<E> visitor); // 通过访问器遍历
    
    public static abstract class Visitor<E>{ // 访问器
        boolean stop;
        public abstract boolean visit(E element);
    }
}

双向链表 LinkedList 实现 ListSet

通过 双向链表 实现 ListSet。

/**
 * LinkedList实现的ListSet
 */
public class ListSet<E> implements Set<E>{
    private LinkedList<E> list = new LinkedList<>();

    public int size() {
        return list.size();
    }

    public boolean isEmpty() {
        return list.isEmpty();
    }

    public void claer() {
        list.clear();
    }

    public boolean contains(E element) {
        return list.contains(element);
    }

    public void add(E element) {
        // if(list.contains(element)) return;
        
        int index = list.indexOf(element);
        if(index == List.ELEMENT_NOT_FOUND){ // 没有该元素
            list.add(element); // 没有就添加
        }else{
            list.set(index, element); // 已经有就替换
        }
    }

    public void remove(E element) {
        int index = list.indexOf(element);
        if(index != List.ELEMENT_NOT_FOUND){
            list.remove(index);
        }
    }

    public void traversal(Visitor<E> visitor) {
        int size = list.size();
        for(int i = 0; i < size; i++){
            visitor.visit(list.get(i));
        }
    }

}

红黑树 RBTree 实现 TreeSet

通过 红黑树 实现的 TreeSet。

/**
 * 红黑树实现集合
 */
public class TreeSet<E> implements Set<E>{
    private RBTree<E> tree = new RBTree<>();
    
    public int size() {
        return tree.size();
    }

    public boolean isEmpty() {
        return tree.isEmpty();
    }

    public void claer() {
        tree.clear();
    }

    public boolean contains(E element) {
        return tree.contains(element);
    }

    public void add(E element) {
        tree.add(element); // 红黑树自带去重
    }

    public void remove(E element) {
        tree.remove(element);
    }

    public void traversal(Visitor<E> visitor) {
        tree.inorder(new BinaryTree.Visitor<E>() {
            @Override
            public boolean visit(E element) {
                return visitor.visit(element);
            }
        });
    }

}

TreeMap 实现 TreeSet

通过 TreeMap 实现 TreeSet。

/**
 * 利用TreeMap实现TreeSet
 */
public class TreeSet<E> implements Set<E> {

    private Map<E, Object> map = new TreeMap<>();
    
    public int size() {
        return map.size();
    }

    public boolean isEmpty() {
        return map.isEmpty();
    }

    public void claer() {
        map.clear();
    }

    public boolean contains(E element) {
        return map.containsKey(element);
    }

    public void add(E element) {
        map.put(element, null);
    }

    public void remove(E element) {
        map.remove(element);
    }

    public void traversal(Visitor<E> visitor) {
        map.traversal(new Map.Visitor<E, Object>() {
            public boolean visit(E key, Object value) {
                return visitor.visit(key);
            }
        });
    }
}

HashMap 实现 HashSet

通过 HashMap 实现 TreeSet。

/**
 * 利用HashMap实现HashSet
 */
public class HashSet<E> implements Set<E> {
    private HashMap<E, Object> map = new HashMap<>();

    public int size() {
        return map.size();
    }

    public boolean isEmpty() {
        return map.isEmpty();
    }
    
    public void clear() {
        map.clear();
    }

    public boolean contains(E element) {
        return map.containsKey(element);
    }

    public void add(E element) {
        map.put(element, null);
    }

    public void remove(E element) {
        map.remove(element);
    }

    public void traversal(Visitor<E> visitor) {
        map.traversal(new Map.Visitor<E, Object>() {
            public boolean visit(E key, Object value) {
                return visitor.visit(key);
            }
        });
    }

}
相关文章
|
9月前
|
算法 Python
【Python深入学习】- 书籍推荐|数据结构和算法介绍|内建集合数据类型
【Python深入学习】- 书籍推荐|数据结构和算法介绍|内建集合数据类型
79 1
|
22天前
|
Java
【Java集合类面试二十六】、介绍一下ArrayList的数据结构?
ArrayList是基于可动态扩展的数组实现的,支持快速随机访问,但在插入和删除操作时可能需要数组复制而性能较差。
|
4月前
|
存储 索引
【数据结构】HashSet的底层数据结构
【数据结构】HashSet的底层数据结构
30 2
|
4月前
|
算法 Java 数据库连接
Spring+MySQL+数据结构+集合,Alibaba珍藏版mybatis手写文档
Spring+MySQL+数据结构+集合,Alibaba珍藏版mybatis手写文档
|
20天前
|
存储 安全
集合的特点和数据结构总结
集合的特点和数据结构总结
13 1
|
4月前
|
缓存 算法 安全
Java集合框架:深入探究数据结构与算法的精华
Java集合框架:深入探究数据结构与算法的精华
|
3月前
|
存储 Python 容器
Python零基础入门-5 数据结构(集合和字典)
Python零基础入门-5 数据结构(集合和字典)
|
3月前
|
算法 Java
Java数据结构与算法:用于处理不相交集合的合并和查找问题
Java数据结构与算法:用于处理不相交集合的合并和查找问题
|
3月前
|
存储 算法
数据结构学习记录——集合及运算(集合的表示、并查集、树结构表示集合、集合运算、查找函数、并运算)
数据结构学习记录——集合及运算(集合的表示、并查集、树结构表示集合、集合运算、查找函数、并运算)
21 0
|
4月前
|
存储 程序员 索引
数据结构深度剖析:列表、元组、字典和集合
【4月更文挑战第8天】Python的四种基础数据结构——列表、元组、字典和集合,各自拥有独特的特性和应用场景。列表是可变序列,方便增删改元素;元组不可变,常用于保证数据不变性;字典是键值对容器,快速访问通过键;集合是无序不重复元素集,适合成员测试和去重。理解并灵活运用这些数据结构,能提升代码效率,有效处理和分析数据。
51 1