FCC算法题—Inventory Update
Inventory Update
题目要求:依照一个存着新进货物的二维数组,更新存着现有库存(在 arr1 中)的二维数组. 如果货物已存在则更新数量 . 如果没有对应货物则把其加入到数组中,更新最新的数量. 返回当前的库存数组,且按货物名称的字母顺序排列. 这是一些对你有帮助的资源: Global Array Object
思路:分析题意,arr1和arr2都是二维数组,切都是键值对。我们要做的是比较两个键值对中的key,如果key相同,就把value相加,如果不同,就把该项加入到arr1中更新。
完整代码:
function updateInventory(arr1, arr2) {
arr2 = arr2.filter(function(temp){
var res = true;
for(var i=0;i<arr1.length;i++){
if(temp[1] === arr1[i][1]){
arr1[i][0]+=temp[0];
res = false;
}
}
return res;
});
//使用filter方法筛选arr2。如果arr1中包含有该项则使value相加,且在arr2中删除该项。
arr1 = arr1.concat(arr2);
//合并arr1和筛选后的arr2。
arr1.sort(function(a,b){
return a[1].charCodeAt(0)-b[1].charCodeAt(0);
});
return arr1;
}
//给arr1排序且返回arr1.
// 仓库库存示例
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);
转载请注明出处。