首页 > 代码库 > FCC高级习题

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

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

  • Array.reduce()
  • Symmetric Difference   

直接上代码:

function sym(args) {
//首先要把传入的参数都转化到一个数组中去 var arr = []; for(var i = 0; i < arguments.length; i++){ arr.push(arguments[i]); }
//使用reduce方法迭代,将不重复出现在下一个参数的数字取出来组成新数组再和后面的数组对比迭代。 var temp=arr.reduce(function(prev,cur,index,array){ var a = prev.filter(function(item){ return cur.indexOf(item)<0; }); var b = cur.filter(function(item){ return prev.indexOf(item)<0; }); return a.concat(b); });
//最后把得到的数组去重,利用fifter方法,函数出现的位置和索引相同时保留达到剔除重复数字的作用。 return temp.filter(function(item,index,array){ return array.indexOf(item)==index; }); //或者调用外部函数去重;function unique(array)见“思路”部分 //return unique(temp); } sym([3, 3, 3, 2, 5], [2, 1, 5, 7], [3, 4, 6, 6], [1, 2, 3]);

  

FCC高级习题