【LeetCode】六、哈希集合Set相关:存在重复元素判断 + MyHashSet设计

文章目录

1、Set集合

  • 无序:写进去的顺序和遍历读出来的顺序不一样
  • 不重复

主要作用:查看是否有重复元素(给一个数组,转为set,数组的长度 > set的长度,即有重复元素)

时间复杂度:

2、Java中的Set集合


3、leetcode217:存在重复元素

思路:重复的判断,借助数据结构的set,数组的长度 > set集合的长度,即有重复。相比之前对这个题的解法,很明显的感觉到,用上数据结构,比无脑for循环要快很多。

java 复制代码
public class P217Two {

    public static boolean isExistSameElement(int[] array) {
        if (array == null || array.length == 0) {
            return false;
        }
        HashSet<Integer> set = new HashSet<>();
        for (int i : array) {
            set.add(i);
        }
        return array.length > set.size();
    }
}

测试:

java 复制代码
public class P217Two {
    public static void main(String[] args) {
        int[] array = {1, 2, 3, 4, 5};
        System.out.println(isExistSameElement(array));
    }
}

4、P705:设计哈希集合

实现自己的HashSet类,那也就要达到搜索、插入、删除的时间复杂度为O(1),考虑用一个boolean类型的数组,每个元素默认值自然是boolean的默认值false,此时,放进来一个1,就把下标索引为1的地方改为true,删除一个10,就把下标索引为10的地方改为false,重复放进来同一个值,仍然为true,符合Set集合的不重复

这种解法的缺点:

  • 数组初始化长度怎么确定(int[] array; 只定义不初始化数组,没法往里面放元素)
  • 比如题目规定了数据范围在0 - 1000w,一下创建这么长一个数组,对连续的内存空间要求太高
java 复制代码
class MyHashSet {
    boolean[] array;

    public MyHashSet() {
        array = new boolean[10000];
    }
    public MyHashSet(int size) {
        array = new boolean[size];
    }

    // 新增元素
    public void add(int key) {
        array[key] = true;
    }

    // 移除元素
    public void remove(int key) {
        array[key] = false;
    }

    // 是否包含某个元素
    public boolean contains(int key) {
        return array[key];
    }
}

测试:

java 复制代码
public class P705 {
    public static void main(String[] args) {
        MyHashSet myHashSet = new MyHashSet();
        myHashSet.add(1);
        myHashSet.add(2);
        System.out.println(myHashSet.contains(1));  // 返回True
        System.out.println(myHashSet.contains(3)); // 返回 False ,(未找到)
        myHashSet.add(2);
        System.out.println(myHashSet.contains(2)); // 返回 True
        myHashSet.remove(2);
        System.out.println(myHashSet.contains(2)); // 返回 False ,(已移除)
    }
}
相关推荐
铭哥的编程日记2 分钟前
后端面试通关笔记:从真题到思路(me)
笔记·面试·职场和发展
天呐草莓4 分钟前
支持向量机(SVM)
人工智能·python·算法·机器学习·支持向量机·数据挖掘·数据分析
zore_c16 分钟前
【数据结构】队列——超详解!!!(包含队列的实现)
c语言·网络·数据结构·c++·笔记·算法·链表
小杰帅气17 分钟前
智能指针喵喵喵
开发语言·c++·算法
智驱力人工智能27 分钟前
守护生命的水上之眼 无人机人员落水检测系统的技术攻坚与应用实践 无人机溺水识别 山区水库无人机落水检测系统 水域安全无人机部署指南
大数据·人工智能·算法·安全·无人机·边缘计算
hweiyu0028 分钟前
排序算法选型决策树
算法·排序算法
蓝色汪洋2 小时前
xtu oj矩阵
算法
hh随便起个名9 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
写写闲篇儿9 小时前
微软面试之白板做题
面试·职场和发展
Dingdangcat8610 小时前
城市交通多目标检测系统:YOLO11-MAN-FasterCGLU算法优化与实战应用_3
算法·目标检测·目标跟踪