大家好,我是木川
一、题目描述
给定两个数组nums1和nums2,返回它们的交集。输出结果中的每个元素一定是唯一的。我们可以不考虑输出结果的顺序。
示例 1:
输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2]
示例 2:
输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]
解释:[4,9] 也是可通过的
提示:
二、题解一)哈希表
思路:
1、遍历数组1,使用辅助哈希表存储已有元素
2、遍历数组2,如果遍历元素在哈希表中存在,则保存到结果数组中
代码:
func intersection(nums1 []int, nums2 []int) []int {
set := make(map[int]struct{})
res := make([]int, 0)
for _, v := range nums1 {
set[v] = struct{}{}
}
for _, v := range nums2 {
if _, ok := set[v]; ok {
res = append(res, v)
// 去重
delete(set, v)
}
}
return res
}
时间复杂度:O(n)
空间复杂度:O(n)
二)排序 + 双指针
如果两个数组是有序的,则可以使用双指针的方法得到两个数组的交集
思路:
1、首先对两个数组进行排序
2、两个指针分别指向两个数组的头部,每次比较两个指针指向的两个数组中的数字,如果两个数字不相等,则将指向较小数字的指针右移一位,如果两个数字相等,将该数字添加到答案,同时将两个指针都右移一位
代码:
func intersection(nums1 []int, nums2 []int) (res []int) {
sort.Ints(nums1)
sort.Ints(nums2)
for i, j := 0, 0; i < len(nums1) && j < len(nums2); {
x, y := nums1[i], nums2[j]
if x == y {
// 去除重复(相同的元素)
if res == nil || x != res[len(res)-1] {
res = append(res, x)
}
i++
j++
} else if x < y {
i++
} else {
j++
}
}
return res
}
时间复杂度:O(mlogm+nlogn),其中 m 和 n 分别是两个数组的长度,对两个数组排序的时间复杂度分别是 O(mlogm) 和 O(nlogn),双指针寻找交集元素的时间复杂度是 O(m+n),因此总时间复杂度是 O(mlogm+nlogn)
空间复杂度:排序使用的额外空间 O(logm+logn),其中 m 和 n 分别是两个数组的长度。
今天的分享就到这里了,加下面微信拉你进编程技术交流群
如果对你有帮助,帮我点一下在看或转发,欢迎关注我的公众号
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,一年会员只需98元,全站资源免费下载 点击查看详情
站 长 微 信: lzxmw777
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。