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

导读:本篇文章讲解 哈希表系列② — 两个数组的交集,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

也许你感觉自己的努力总是徒劳无功,但不必怀疑,你每天都离顶点更进一步。今天的你离顶点还遥遥无期。但你通过今天的努力,积蓄了明天勇攀高峰的力量。加油!

题目概述

对应力扣的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

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!