首页 > 代码库 > 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高级习题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。