首页 > 代码库 > FCC-AAS2-Symmetric Difference

FCC-AAS2-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}).

当你遇到困难的时候,记得查看错误提示、阅读文档、搜索、提问。

这是一些对你有帮助的资源:

  • Array.reduce()
  • Symmetric Difference

 

 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]) 应该只包含八个元素.
 
---------------------------------------------------------------------------------------
 
我的Free Code Camp地址.
 

FCC-AAS2-Symmetric Difference