题目概述
对应力扣的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计算的。在数据量大的情况,差距是很明显的。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/122265.html