哈希表系列② -- 两个数组的交集

本文介绍了如何使用Java的Set数据结构解决LeetCode中的349题,即找到两个数组的交集。通过创建两个Set,一个用于存储第一个数组的唯一元素,另一个用于存储交集。遍历第二个数组,如果元素存在于第一个Set中,则添加到交集Set中。最后将交集Set转换为数组返回。文章讨论了数组和Set在空间效率和查找速度上的优缺点。
摘要由CSDN通过智能技术生成

题目概述

对应力扣的349.两个数组的交集

给定两个数组 nums1 和 nums2 ,返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。
示例:
输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2]
输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]
解释:[4,9] 也是可通过的

解题思路

此题纯粹的利用Set(集)的性质进行解题。

思路也很简单,创造两个Set(一个作为第一个数组的去重容器,另外一个作为交集结果集),将第一个数组往其中添加。然后再遍历第二个数组,如果元素在第一个Set中存在,我们就把这个元素添加到结果集Set当中。最后只用把结果集中元素全部放到数组中返回即可。

代码实现

class Solution {
    public int[] intersection(int[] a, int[] b) {
        Set<Integer> box1 = new HashSet<>();
		Set<Integer> box2 = new HashSet<>();
		for(int num : a) box1.add(num);
		for(int i : b) {
			if (box1.contains(i)) box2.add(i);
		}
		int[] result = new int[box2.size()];
		int flag = 0;
		for(int ans : box2) {
			result[flag] = ans; 
			flag++;
		} 
		return result;
    }
}

小总结

数组的缺点:如果哈希值比较少、特别分散、跨度非常大,使用数组就造成空间的极大浪费!

Set的缺点:直接使用set 不仅占用空间比数组大,而且速度要比数组慢,set把数值映射到key上都要做hash计算的。在数据量大的情况,差距是很明显的。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

十八岁讨厌编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值