1.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}
).
这是一些对你有帮助的资源:
直接上代码:
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]);
2.
Inventory Update
依照一个存着新进货物的二维数组,更新存着现有库存(在 arr1
中)的二维数组. 如果货物已存在则更新数量 . 如果没有对应货物则把其加入到数组中,更新最新的数量. 返回当前的库存数组,且按货物名称的字母顺序排列.
function updateInventory(arr1, arr2) { // All inventory must be accounted for or you're fired! var oCur={}; var oNew={}; function arrToObj(arr,obj){ } // Example inventory lists var curInv = [ [21, "Bowling Ball"], [2, "Dirty Sock"], [1, "Hair Pin"], [5, "Microphone"] ]; var newInv = [ [2, "Hair Pin"], [3, "Half-Eaten Apple"], [67, "Bowling Ball"], [7, "Toothpaste"] ]; updateInventory(curInv, newInv);
面对这道题目,解题思路一般是,先遍历第一个数组每一项的第二项,然后检查数组中的第二个值是否出现在第二个数组,如果有则更新第二个数组对应项的第一个值,如果没有则将第一个数组的这一项添加到第二个数组。
解法如下:
function updateInventory(arr1, arr2) { // All inventory must be accounted for or you're fired! if(arr1.length === 0){ arr1 = arr2; } else{ arr1.forEach(function(item,index,array){ for(var i=0;i<arr2.length;i++){ if(item[1]==arr2[i][1]){ item[0]+=arr2[i][0]; break; } if(arr1.join().indexOf(arr2[i][1])<0){ arr1.push(arr2[i]); } } }); } arr1.sort(function(a,b){ return a[1]>b[1]; }); return arr1; }
补充说明,看到了另外一个想法,大概内容是将两个数组里的每一项都转化为属性和值的关系(key,val),构建两个数组对象。然后使用hasOwnProperty的方法进行判断是否存在。如果有,则累加,如果没有则把该对象添加到第二个数组。
var oCur={}; var oNew={}; function arrToObj(arr,obj){ for(var i=0;i<arr.length;i++){ obj[arr[i][1]]=arr[i][0]; } }//构造库存对象。 arrToObj(arr1,oCur); arrToObj(arr2,oNew);
上面的代码为两个数组构造对象。然后遍历数组的每个对象
for(i in oNew){ console.log(oCur.hasOwnProperty(i)) if(oCur.hasOwnProperty(i)){ oCur[i]+=oNew[i]; }else{ oCur[i]=oNew[i]; } }
如果有该属性则累加数值,没有则完整添加。
最后是为新的数组进行排序:
Object.keys(obj).sort();
function objKeySort(obj) {//排序的函数 var newkey = Object.keys(obj).sort(); //newkey是一个排序后的属性名数组 var newObj = {}; for (var i = 0; i < newkey.length; i++) { newObj[newkey[i]] = obj[newkey[i]]; } return newObj;//返回排好序的新对象 } oCur=objKeySort(oCur); //反向编译这个对象,然后返回成最初的数组。 var newArr=[] for(i in oCur){ newArr.push([oCur[i],i]) } console.log(newArr); return newArr; }
第二个方法主要是想学习一下 如何构建数组对象,将给定的两个二维数组变成了key和val的数组。
obj[arr[i][1]]=arr[i][0];