es6 利用集合Set解决数组交集、并集、差集问题
2019-07-13 本文已影响7人
charoner
本篇提供了解决两个数组交集、并集、差集问题的方案,阅读阮一峰老师的ESMAScript 6入门 中的新数据结构Set() 总结所得:
属性与实例方法:
ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。
Set.prototype.constructor:构造函数,默认就是Set函数。
Set.prototype.size:返回Set实例的成员总数。
Set 实例的方法分为两大类:操作方法(用于操作数据)和遍历方法(用于遍历成员)。下面先介绍四个操作方法。
Set.prototype.add(value):添加某个值,返回 Set 结构本身。
Set.prototype.delete(value):删除某个值,返回一个布尔值,表示删除是否成功。
Set.prototype.has(value):返回一个布尔值,表示该值是否为Set的成员。
Set.prototype.clear():清除所有成员,没有返回值。
代码实现:
//两个数组
let a = new Set([2, 4, 5, 3])
let b = new Set([3, 5, 1, 6])
//求交集
let intersect = [...a].filter(item => b.has(item))
console.log(intersect) //[5, 3]
//求差集
let difference = [...a].filter(item => !b.has(item))
console.log(difference) //[2, 4]
//求并集
let union = [...new Set([...a, ...b])]
console.log(union) //[2, 4, 5, 3, 1, 6]