FCC算法题--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 3 var arr = []; 4 5 //把变量放在一个数组里 6 for(var i=0; i<arguments.length; i++) { 7 arr.push(arguments[i]); //[[1,2,3],[5,2,1,4]] 8 } 9 10 //找出只在各自集合中的元素 11 var temp = arr.reduce(function(prev,cur,index,array) { 12 //返回prev中cur没有的元素 13 var onlyInPrev = prev.filter(function(item){ 14 return cur.indexOf(item) === -1; //[3] 15 }); 16 //返回cur中prev没有的元素 17 var onlyInCur = cur.filter(function(item){ 18 return prev.indexOf(item) === -1; //[5,4] 19 }); 20 //合并 21 return onlyInPrev.concat(onlyInCur); 22 }); 23 24 //return temp; 25 //去掉重复的数字 26 return temp.filter(function(item,index,array){ 27 return array.indexOf(item) === index; 28 }); 29 30 } 31 32 sym([1, 2, 3], [5, 2, 1, 4]);
sym([1, 2, 3], [5, 2, 1, 4])
应该返回 [3, 4, 5]
.sym([1, 2, 3], [5, 2, 1, 4])
应该只包含三个元素.sym([1, 2, 5], [2, 3, 5], [3, 4, 5])
应该返回 [1, 4, 5]
sym([1, 2, 5], [2, 3, 5], [3, 4, 5])
应该只包含三个元素.sym([1, 1, 2, 5], [2, 2, 3, 5], [3, 4, 5, 5])
应该返回 [1, 4, 5]
.sym([1, 1, 2, 5], [2, 2, 3, 5], [3, 4, 5, 5])
应该只包含三个元素.sym([3, 3, 3, 2, 5], [2, 1, 5, 7], [3, 4, 6, 6], [1, 2, 3])
应该返回 [2, 3, 4, 6, 7]
.sym([3, 3, 3, 2, 5], [2, 1, 5, 7], [3, 4, 6, 6], [1, 2, 3])
应该只包含五个元素.sym([3, 3, 3, 2, 5], [2, 1, 5, 7], [3, 4, 6, 6], [1, 2, 3], [5, 3, 9, 8], [1])
应该返回 [1, 2, 4, 5, 6, 7, 8, 9]
.sym([3, 3, 3, 2, 5], [2, 1, 5, 7], [3, 4, 6, 6], [1, 2, 3], [5, 3, 9, 8], [1])
应该只包含八个元素.---------------------------------------------------------------------------------------