码迷,mamicode.com
首页 > 编程语言 > 详细

数组的 交集 差集 补集 并集

时间:2019-09-21 16:49:55      阅读:72      评论:0      收藏:0      [点我收藏+]

标签:并集   es6   div   highlight   dex   intersect   new   nio   from   

ES5的写法
var a = [1,2,3,4,5]
var b = [2,4,6,8,10]

// //交集
var c = a.filter(function(v){ return b.indexOf(v) > -1 })
// //差集
var d = a.filter(function(v){ return b.indexOf(v) == -1 })
// //补集
var e = a.filter(function(v){ return !(b.indexOf(v) > -1) })
 .concat(b.filter(function(v){ return !(a.indexOf(v) > -1)}))
//并集
var f = a.concat(b.filter(function(v){ return !(a.indexOf(v) > -1)}));
console.log("数组a:", a);
console.log("数组b:", b);
console.log("a与b的交集:", c);
console.log("a与b的差集:", d);
console.log("a与b的补集:", e);
console.log("a与b的并集:", f);
 
用ES6 的写法
var a = [1,2,3,4,5]
var b = [2,4,6,8,10]
console.log("数组a:", a);
console.log("数组b:", b);
var sa = new Set(a);
var sb = new Set(b);
// 交集
let intersect = a.filter(x => sb.has(x));
// 差集
let minus = a.filter(x => !sb.has(x));
// 补集
let complement = [...a.filter(x => !sb.has(x)), ...b.filter(x => !sa.has(x))];
// 并集
let unionSet = Array.from(new Set([...a, ...b]));
console.log("a与b的交集:", intersect);
console.log("a与b的差集:", minus);
console.log("a与b的补集:", complement);
console.log("a与b的并集:", unionSet);

  

 
 

数组的 交集 差集 补集 并集

标签:并集   es6   div   highlight   dex   intersect   new   nio   from   

原文地址:https://www.cnblogs.com/buxiugangzi/p/11563488.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!