Symmetric Difference
创建一个函数,接受两个或多个数组,返回所给数组的 对等差分(symmetric difference) (△
or ⊕
)数组.
给出两个集合 (如集合 A = {1, 2, 3}
和集合 B = {2, 3, 4}
), 而数学术语 "对等差分" 的集合就是指由所有只在两个集合其中之一的元素组成的集合(A △ B = C = {1, 4}
). 对于传入的额外集合 (如 D = {2, 3}
), 你应该安装前面原则求前两个集合的结果与新集合的对等差分集合 (C △ D = {1, 4} △ {2, 3} = {1, 2, 3, 4}
).
代码:
1 function sym(args) { 2 var arr=[]; 3 for(var i=0;i<arguments.length;i++){ 4 arr.push(arguments[i]); 5 } 6 arr=arr.reduce(function(a,value){ 7 //利用reduce让每个数组互相差分 8 var arr1=a.filter(function(val){ 9 return value.indexOf(val)===-1; 10 }); 11 var arr2=value.filter(function(val){ 12 return a.indexOf(val)===-1; 13 }); 14 a=arr1.concat(arr2); 15 console.log(a); 16 return a; 17 }); 18 var array=[]; 19 for(var j=0;j<arr.length;j++){ 20 //消除arr中重复的元素 21 if(array.indexOf(arr[j])===-1){ 22 array.push(arr[j]); 23 } 24 25 } 26 return array; 27 } 28 29 sym([1, 1, 2, 5], [2, 2, 3, 5], [3, 4, 5, 5]);