首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JavaScript -比较两个数组并返回两个数组中不存在的数组

JavaScript是一种广泛应用于前端开发的编程语言,它具有动态类型、面向对象和函数式编程的特性。在JavaScript中,可以使用以下方法来比较两个数组并返回两个数组中不存在的数组:

  1. 使用filter()方法和includes()方法:
代码语言:txt
复制
function compareArrays(arr1, arr2) {
  const diff1 = arr1.filter(item => !arr2.includes(item));
  const diff2 = arr2.filter(item => !arr1.includes(item));
  return [...diff1, ...diff2];
}

const array1 = [1, 2, 3, 4, 5];
const array2 = [3, 4, 5, 6, 7];
const result = compareArrays(array1, array2);
console.log(result); // [1, 2, 6, 7]

这段代码首先使用filter()方法过滤出在arr1中存在但在arr2中不存在的元素,然后使用filter()方法过滤出在arr2中存在但在arr1中不存在的元素,最后将两个数组合并成一个新数组返回。

  1. 使用reduce()方法和includes()方法:
代码语言:txt
复制
function compareArrays(arr1, arr2) {
  const diff = arr1.reduce((result, item) => {
    if (!arr2.includes(item)) {
      result.push(item);
    }
    return result;
  }, []);
  return diff;
}

const array1 = [1, 2, 3, 4, 5];
const array2 = [3, 4, 5, 6, 7];
const result = compareArrays(array1, array2);
console.log(result); // [1, 2, 6, 7]

这段代码使用reduce()方法遍历arr1数组,如果当前元素不在arr2数组中,则将其添加到结果数组中。

  1. 使用Set对象:
代码语言:txt
复制
function compareArrays(arr1, arr2) {
  const set1 = new Set(arr1);
  const set2 = new Set(arr2);
  const diff = [...arr1.filter(item => !set2.has(item)), ...arr2.filter(item => !set1.has(item))];
  return diff;
}

const array1 = [1, 2, 3, 4, 5];
const array2 = [3, 4, 5, 6, 7];
const result = compareArrays(array1, array2);
console.log(result); // [1, 2, 6, 7]

这段代码首先使用Set对象将arr1和arr2转换为集合,然后使用filter()方法过滤出在一个集合中存在但在另一个集合中不存在的元素,最后将两个数组合并成一个新数组返回。

以上是三种常见的比较两个数组并返回两个数组中不存在的数组的方法。根据具体的业务需求和数据规模,选择合适的方法来实现。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

java 两个数组集_Java程序获取两个数组

参考链接: Java程序来计算两个集合集 java 两个数组集   快速和编程指南,介绍如何使用示例程序在java获得两个未排序数组联合。   ...1.概述   在本文中,您将学习如何在java获得两个数组集。 集是两个集合或所有集合所有值。    我们可以使用带有数组HashSet在Java执行集函数。...2.两个带数字整数数组集   让我们编写Java程序来打印两个整数数组集。   ...String数组集   让我们编写Java程序来打印两个String数组集。   ...结论   在本文中,我们已经看到了如何使用HashSet在Java中找到两个数组集。    像往常一样,所有示例。 结束了Github 。    如何比较两个字符串?

1.6K30

两个数组交集?如果两个数组是有序呢?

第350题:给定两个数组,编写一个函数来计算它们交集。 ? 给定两个数组,编写一个函数来计算它们交集。...,应与元素在两个数组中出现次数一致。...我们可以不考虑输出结果顺序。 进阶: 如果给定数组已经排好序呢?你将如何优化你算法? 设定两个为0指针,比较两个指针元素是否相等。...两个排序好数组题,我们很容易可以想到通过双指针解法~ 设定两个为0指针,比较两个指针元素是否相等。如果指针元素相等,我们将两个指针一起向前移动,并且将相等元素放入空白数组。 ?...提示:解答我们并没有创建空白数组,因为遍历后数组其实就没用了。我们可以将相等元素放入用过数组,就为我们节省下了空间。

1.4K40

两个数组交集

本文链接:https://blog.csdn.net/weixin_43908900/article/details/102591900 题目:给定两个数组,编写一个函数来计算它们交集。...我们可以不考虑输出结果顺序。 首先说一下我自己(菜鸡)思路:我先是想先去重第第一个数组(nums1),然后循环判断值是否在nums2,有的话,添加新列表。...比我自己做快了24ms,值得深思问题,复杂度分析, 时间复杂度:O(m+n)O(m+n),其中 n 和 m 是数组长度。...O(n)O(n) 时间用于转换 nums1 在集合,O(m)O(m) 时间用于转换 nums2 到集合,并且平均情况下,集合操作为 O(1)O(1)) 空间复杂度:O(m+n)O(m+n),最坏情况是数组所有元素都不同...空间复杂度:最坏情况是 O(m+n)O(m+n),当数组元素全部不一样时。 只能说还是太菜。。。。。。。。

1.6K00

两个数组交集

两个数组交集 给定两个数组,编写一个函数来计算它们交集。...,计算两个数组交集最简单方式就是遍历数组nums1,对于其中每个元素,遍历数组nums2判断该元素是否在数组nums2,如果存在,则将该元素添加到返回值,这样方式时间复杂度是O(mn),在这里使用排序加双指针方式...,首先对于两个数组分别进行排序,之后分别对于两个数组设立指针进行遍历,对比两个指针所指向元素,较小指针后移,如果相等则判断是否已经在目标数组,不在则将其推入数组,之后同时将两个指针后移,最终返回目标数组即可...,将i指针后移,如果大于则将k指针后移,如果相等则首先得到目标数组最后一个值索引,当然在数组为空情况下会得到-1,在Js中会取得undefined值,在下方比较时不会相等,之后比较最后一个值是否与此时指针指向值相等...,不相等则将值推入数组,这样用来进行去重操作,之后将两个指针分别后移,循环结束后返回目标数组即可。

1.2K30

两个数组交集II

JavaScript实现LeetCode第350题:两个数组交集II 题目描述 给定两个数组,编写一个函数来计算它们交集。...解题思路 幼稚方法是根据第一个数组 nums1 迭代检查每个值是否存在在 nums2 内。如果存在将值添加到输出。这样方法会导致 O(nxm) 时间复杂性,其中 n 和 m 是数组长度。...O(n^2) 使用 Map 在 实现 349.两个数组交集[1],我们使用 Set来实现线性时间复杂度,在这里我们要使用 Map 来跟踪每个数字出现次数 现在 Map 记录一个数组存在数字和对应次数..., 然后,我们遍历第二个数组,检查数字在 Map是否存在, 如果存在且计数为正,且将该数字添加到答案减少 map 计数 检查数组大小对较小数组进行哈希映射是一个小细节,当其中一个数组较大时...将两个数组进行排序,然后用双指针顺序查找相同元素 时间复杂度O(max(nlogn, mlogm, n+m)),空间复杂度O(1) (n,m分别为两个数组长度) 如果是进阶问题一已排序数组,则只需

93240

【Leetcode -349.两个数组交集 -350.两个数组交集Ⅱ】

Leetcode -349.两个数组交集 题目:给定两个数组 nums1 和 nums2 ,返回 它们交集 。 输出结果每个元素一定是 唯一 。我们可以 不考虑输出结果顺序 。...//遍历nums2数组,检查以nums2作为hash数组下标,若以这个数作为下标的hash数组数已经被标记为1, //证明已经出现过,就将它放进已开辟好数组p,...len *returnSize = len; return p; } Leetcode - 350.两个数组交集Ⅱ 给你两个整数数组 nums1 和 nums2 ,请你以数组形式返回数组交集...返回结果每个元素出现次数,应与元素在两个数组中都出现次数一致(如果出现次数不一致,则考虑取较小值)。可以不考虑输出结果顺序。...数组数作为下标的hash数组位置数是否大于0 //大于0证明这个数也在nums1数组中出现过,将它放进p数组记录p数组长度k //随后将这个数作为下标的hash数组位置自减

7610

JavaScript | 数组splice()方法,向从数组添加删除项目,返回删除项目

JavaScript代码: /* * splice() 方法向/从数组添加/删除项目,返回删除项目。 * 注释:splice() 方法会改变原始数组。...整数,指定在什么位置添加/删除项目,使用负值指定从数组末尾开始位置。 * howmany:可选。要删除项目数。如果设置为 0,则不会删除任何项目。...要添加到数组新项目。 * 返回值:一个新数组,包含删除项目(如果有)。...let delItem = cars.splice(3, 1); console.log("删除bmw:",JSON.stringify(cars)) console.log("被删除元素是...(cars)) cars.splice(-2, 1); console.log("index传-2,指定从数组末尾开始数2个:",JSON.stringify(cars)) 打印输出结果

3.2K10

两个数组交集 II

给定两个数组,编写一个函数来计算它们交集。...,应与元素在两个数组中出现次数最小值一致。...如果 nums2 元素存储在磁盘上,内存是有限,并且你不能一次加载所有的元素到内存,你该怎么办?...题目信息 输入:两个整数数组 输出:交集数组 额外:不考虑顺序 思考 就相当于是数学集合求交集,很容易想到就是双指针扫描比较判断是否存入结果。对于这样方式就选择先排序再比较。...,第二种先将一个数组统计到hash表另一个再对照查找存不存在,对于进阶里面的三条第一条是已经排好序那么遍历直接比较即可时间复杂度O(n+m),如果两数组长度差距大的话首先空间优化创建result数组用小那个容量创建其他就是对使用

93920

两个数组交集II

两个数组交集II 给定两个数组,编写一个函数来计算它们交集。...,应与元素在两个数组中出现次数最小值一致。...,而Js对象也是以HashTable进行存储,便可以直接利用Js对象来实现哈希表,请注意题目要求结果每个元素出现次数应与元素在两个数组中出现次数最小值一致,根据这个要求那么需要在哈希表记录值出现次数...,首先定义一个HashTable用以记录值出现次数,然后定义目标数组,接着将第一个数组nums1进行遍历,在哈希表如果没有定义这个key,那么就将这个key值设置为1,如果已经定义了,那么就将其值自增...,然后遍历第二个数组nums2,直接判断在哈希表是否定义该key,如果定义且其计数值大于0,那么就将哈希表该key计数值自减,然后将该key推入数组,循环结束后返回目标数组即可。

1.2K10
领券