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

举报
十八岁讨厌编程 发表于 2022/08/06 02:01:08 2022/08/06
【摘要】 文章目录 题目概述解题思路代码实现小总结 题目概述 对应力扣的349.两个数组的交集 给定两个数组 nums1 和 nums2 ,返回 它们的交集 。输出结果中的每个元素一定是 唯...

题目概述

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

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

小总结

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

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

文章来源: blog.csdn.net,作者:十八岁讨厌编程,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/zyb18507175502/article/details/123307116

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。