【Leetcode】349. 两个数组的交集

本文解析了如何使用哈希表实现LeetCode中的349题,即找出两个整数数组的交集。通过构建两个映射(hash),统计每个数组中元素的出现情况,然后遍历第一个hash,检查元素是否也在第二个hash中,将存在交集的元素添加到答案数组中。
摘要由CSDN通过智能技术生成

【Leetcode】349. 两个数组的交集

题目链接

【Leetcode】349. 两个数组的交集

代码

func intersection(nums1 []int, nums2 []int) []int {
	// nums1和nums切片的hash
	hash1 := map[int]bool{}
	hash2 := map[int]bool{}
	// 统计nums1跟nums2中元素的出现情况
	for _, num := range nums1 {
		hash1[num] = true
	}
	for _, num := range nums2 {
		hash2[num] = true
	}
	ans := make([]int, 0)
	// 枚举hash1,判断元素在hash2中是否存在,存在的放到结果切片中
	for key := range hash1 {
		if _, ok := hash2[key]; ok {
			ans = append(ans, key)
		}
	}
	return ans
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值