349. 两个数组的交集 -力扣(leetCode)JS解法

本文介绍了如何利用JavaScript中的Set和filter方法高效地找出两个数组的交集。通过创建nums1的集合去重,然后使用filter方法筛选nums2中包含的元素,实现O(n)的时间复杂度解决方案。示例展示了具体实现过程,并分析了时间复杂度为O(m*n)和空间复杂度为O(n)。
摘要由CSDN通过智能技术生成

⚡️349. 两个数组的交集⚡️
给定两个数组,编写一个函数来计算它们的交集。

示例 1:
输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2]

示例 2:
输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]

说明:
输出结果中的每个元素一定是唯一的。
我们可以不考虑输出结果的顺序。


⚡️分析⚡️

既然提示了交集,那么用集合的思想来解即可,将其中一个数组去重后,结合数组的filter(筛选)和includes(有无相同元素)方法即可

代码如下:

/**
 * @param {number[]} nums1
 * @param {number[]} nums2
 * @return {number[]}
 */
var intersection = function(nums1, nums2) {
    return [...new Set(nums1)].filter(item => nums2.includes(item))
};

代码分析:先将nums1数组变成集合来去重,接着运用…的展开方法将其加入到新数组里,接着对数组用filter的方法进行筛选合适的返回,
筛选规定为:对于数组中的每项item,都用数组nums2的includes方法判断有没有该项,有就返回true

算法效率如图:
在这里插入图片描述
可以看到性能还是很不错的~

假设nums1长度为m,nums2长度为n
时间复杂度:对于nums1的每一项都对nums2调用includes遍历,因此复杂度为O(n^2),严格来说是O(m*n)
空间复杂度:结果只有取完交集后的nums1,因此为O(n),严格来说是O(m)





觉得该篇文章有用的请不要忘记忘记点击右下角的大拇指~

欢迎大家关注我的公众号:Smooth前端成长记录
公众号同步更新CSDN博客内容,想方便阅读博客的C友可以来关注我的公众号以便获得更优良的阅读体验~
在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值