【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 ,(已移除)
    }
}
相关推荐
白帽黑客-晨哥10 分钟前
Web安全方向的面试通常会重点考察哪些漏洞和防御方案?
安全·web安全·面试·职场和发展·渗透测试
2401_8772742416 分钟前
2025数据结构实验八:排序
数据结构·算法·排序算法
J2虾虾20 分钟前
空间矢量数据结构及其表达
算法
Neil今天也要学习31 分钟前
永磁同步电机无速度算法--永磁同步电机转子位置精确估计的误差抑制方法
算法
Irene199133 分钟前
JavaScript 常见算法复杂度总结(大O表示法)
javascript·算法
开心比对错重要41 分钟前
进程、线程、虚拟线程详解及线程个数设置
java·jvm·算法·面试
爱学大树锯1 小时前
【594 · 字符串查找 II】
java·开发语言·算法
m0_692457101 小时前
图像噪点消除
人工智能·算法
2401_841495641 小时前
【Python高级编程】图着色动态可视化 APP
python·算法·matplotlib·tkinter·回溯法·图着色算法·动态可视化工具
youngee111 小时前
hot100-53搜索旋转排序数组
数据结构·算法·leetcode