0
点赞
收藏
分享

微信扫一扫

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


文章目录

  • ​​题目概述​​
  • ​​解题思路​​
  • ​​代码实现​​
  • ​​小总结​​

题目概述

对应力扣的​​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计算的。在数据量大的情况,差距是很明显的。


举报

相关推荐

0 条评论