294 lines
16 KiB
Markdown
294 lines
16 KiB
Markdown
![]() |
---
|
|||
|
title: Inventory Update
|
|||
|
localeTitle: Обновление инвентаря
|
|||
|
---
|
|||
|
 Не забудьте использовать **`Read-Search-Ask`** если вы застряли. Попробуйте подключить программу  и напишите свой собственный код 
|
|||
|
|
|||
|
###  Проблема Объяснение:
|
|||
|
|
|||
|
В этой проблеме вы должны сравнивать и обновлять инвентарь, хранящийся в 2D-массиве, против второго 2D-массива новой доставки. Обновите текущие объемы инвентарных количеств (в `arr1` ). Если элемент не найден, добавьте новый элемент и количество в массив инвентаря. Возвращаемый массив инвентаря должен быть в алфавитном порядке по позиции.
|
|||
|
|
|||
|
Текущий, а также новый инвентарь будут в этом формате: `[[2, "item-0"], [3, "item-1"], [67, "item-2"], [7, "item-3"]]` .
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [JS Array](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array)
|
|||
|
|
|||
|
##  Подсказка: 1
|
|||
|
|
|||
|
Вам нужно проработать каждый элемент нового инвентаря, чтобы узнать, существует ли он в текущем инвентаре или нет. Помните, что имя продукта хранится как второй элемент каждого вспомогательного массива: `array[0][1] = "item-name"` .
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
##  Подсказка: 2
|
|||
|
|
|||
|
Если элемент существует, вам нужно добавить количество из нового инвентаря. Если элемент не существует, вам необходимо добавить весь элемент.
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
##  Подсказка: 3
|
|||
|
|
|||
|
Верните завершенный инвентарь в алфавитном порядке.
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
## Осторожно, спойлеры!
|
|||
|
|
|||
|

|
|||
|
|
|||
|
**Решение впереди!**
|
|||
|
|
|||
|
##  Решение базового кода:
|
|||
|
|
|||
|
```javascript
|
|||
|
function updateInventory(arr1, arr2) {
|
|||
|
|
|||
|
// Variable for location of product
|
|||
|
var index;
|
|||
|
|
|||
|
// A helper method to return the index of a specified product (undefined if not found)
|
|||
|
var getProductIndex = function (name) {
|
|||
|
for (var i = 0; i < this.length; i++) {
|
|||
|
if (this<a href='https://forum.freecodecamp.com/images/emoji/emoji_one/rocket.png?v=3 ":rocket:"' target='_blank' rel='nofollow'>i][1] === name) {
|
|||
|
return i;
|
|||
|
}
|
|||
|
}
|
|||
|
return undefined;
|
|||
|
}
|
|||
|
|
|||
|
// For each item of the new Inventory
|
|||
|
for (var i = 0; i < arr2.length; i++) {
|
|||
|
|
|||
|
// Invoke our helper function using arr1 as this
|
|||
|
index = getProductIndex.call(arr1, arr2[i][1]);
|
|||
|
|
|||
|
// If the item doesn't exist
|
|||
|
if (index === undefined) {
|
|||
|
// Push the entire item
|
|||
|
arr1.push(arr2[i]);
|
|||
|
} else {
|
|||
|
// Add the new quantity of the current item
|
|||
|
arr1[index][0] += arr2[i][0];
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
// Sort alphabetically, by the product name of each item
|
|||
|
arr1.sort(function (a, b) {
|
|||
|
if (a[1] > b[1]) {
|
|||
|
return 1;
|
|||
|
}
|
|||
|
if (a[1] < b[1]) {
|
|||
|
return -1;
|
|||
|
}
|
|||
|
return 0;
|
|||
|
});
|
|||
|
|
|||
|
return arr1;
|
|||
|
}
|
|||
|
|
|||
|
// test here
|
|||
|
// 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);
|
|||
|
```
|
|||
|
|
|||
|
 [Код запуска](https://repl.it/CLok/0)
|
|||
|
|
|||
|
### Код Объяснение:
|
|||
|
|
|||
|
* **Индексная** переменная хранит расположение (индекс) продукта.
|
|||
|
* Вспомогательная функция `getProductIndex()` возвращает индекс указанного продукта. Он выполняет итерацию через каждый элемент массива, на который он вызывается, пока не найдет параметр имени. Если продукт не найден в инвентаре, возвращается `undefined` .
|
|||
|
* Затем каждый элемент нового инвентаря (доставки) обрабатывается:
|
|||
|
* **index** устанавливается на результат вызова вспомогательной функции, т. е. поиск нового инвентаря для этого имени продукта и возврат его индекса.
|
|||
|
* Если элемент найден, количество продукта добавляется к количеству одного и того же продукта в текущем инвентаре.
|
|||
|
* Если элемент не найден, весь товар (имя и количество) добавляется в текущий инвентарь.
|
|||
|
* Обновленный инвентарь, **arr1** , затем сортируется по названию продукта (проводится в `arr1[x][1]` ).
|
|||
|
* Затем возвращается окончательный - обновленный, а также отсортированный массив.
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [JS это](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Operators/this)
|
|||
|
* [JS Array.length](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/length)
|
|||
|
* [JS Array.prototype.push ()](http://forum.freecodecamp.com/t/javascript-array-prototype-push/14298)
|
|||
|
* [JS Array.prototype.sort ()](http://forum.freecodecamp.com/t/javascript-array-prototype-sort/14306)
|
|||
|
|
|||
|
##  Решение промежуточного кода:
|
|||
|
|
|||
|
```javascript
|
|||
|
function updateInventory(arr1, arr2) {
|
|||
|
// All inventory must be accounted for or you're fired!
|
|||
|
|
|||
|
var index;
|
|||
|
var arrCurInvName = <a href='https://forum.freecodecamp.com/images/emoji/emoji_one/rocket.png?v=3 ":rocket:"' target='_blank' rel='nofollow'>]; // Names of arr1's items
|
|||
|
var arrNeInvName = []; // Names of arr2's items
|
|||
|
|
|||
|
// Same as using two for loops, this takes care of increasing the number of stock quantity.
|
|||
|
arr1.map(function(item1) {
|
|||
|
return arr2.map(function(item2) {
|
|||
|
if (item1[1] === item2[1]) {
|
|||
|
item1[0] = item1[0] + item2[0]; //Increase number of stock
|
|||
|
}
|
|||
|
});
|
|||
|
});
|
|||
|
|
|||
|
// Get item's name for new Inventory
|
|||
|
arr2.map(function(item) {
|
|||
|
arrNeInvName.push(item[1]);
|
|||
|
});
|
|||
|
|
|||
|
// Get item's name for Current Inventory
|
|||
|
arr1.map(function(item) {
|
|||
|
arrCurInvName.push(item[1]);
|
|||
|
});
|
|||
|
|
|||
|
// Add new inventory items to current inventory.
|
|||
|
arrNeInvName.map(function(item) {
|
|||
|
if (arrCurInvName.indexOf(item) === -1) {
|
|||
|
index = arrNeInvName.indexOf(item);
|
|||
|
arr1.push(arr2[index]);
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
// Sort the array alphabetically using the second element of the array as base.
|
|||
|
arr1.sort(function(currItem, nextItem) {
|
|||
|
|
|||
|
//Ternary function to avoid using if else
|
|||
|
return currItem[1] > nextItem[1] ? 1 : -1;
|
|||
|
});
|
|||
|
|
|||
|
return arr1;
|
|||
|
}
|
|||
|
|
|||
|
// test here
|
|||
|
// 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);
|
|||
|
```
|
|||
|
|
|||
|
 [Код запуска](https://repl.it/CLol/0)
|
|||
|
|
|||
|
### Код Объяснение:
|
|||
|
|
|||
|
* **Индексная** переменная хранит расположение (индекс) продукта.
|
|||
|
* **У arrCurInvName** есть имена элементов **arr1** .
|
|||
|
* **Имя arrNeInvName** имеет имена элементов **arr2** .
|
|||
|
* `arr1.map(function(item1))` заботится о предметах, уже существующих в инвентаре, то есть увеличивает количество в инвентаре.
|
|||
|
* Затем `arr2.map(function(item))` и `arr1.map(function(item))` получают имена элементов для нового и текущего инвентаря соответственно.
|
|||
|
* `arrNeInvName.map(function(item))` обрабатывает элементы, которые еще не существуют в инвентаре, то есть добавляет новые предметы в инвентарь.
|
|||
|
* Обновленный массив **arr1** затем сортируется по алфавиту по названию продукта (проводится в `arr1[x][1]` ) и возвращается.
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [JS Array.prototype.map ()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map)
|
|||
|
* [JS Array.prototype.indexOf ()](http://forum.freecodecamp.com/t/javascript-array-prototype-indexof/14291)
|
|||
|
* [Терминальный оператор JS](http://forum.freecodecamp.com/t/javascript-ternary-operator/15973)
|
|||
|
|
|||
|
##  Расширенное решение для кода:
|
|||
|
|
|||
|
```javascript
|
|||
|
function updateInventory(arr1, arr2) {
|
|||
|
// All inventory must be accounted for or you're fired!
|
|||
|
|
|||
|
// convert current inventory (arr1) to an one-dimensional array
|
|||
|
const inventory = Array.prototype.concat.apply([], arr1);
|
|||
|
|
|||
|
// loop through new delivery (arr2)
|
|||
|
for (let i = 0; i < arr2.length; i++) {
|
|||
|
|
|||
|
// extract item properties for easy reference
|
|||
|
const item = arr2[i][1];
|
|||
|
const quantity = arr2[i][0];
|
|||
|
|
|||
|
// check if item already exists in inventory
|
|||
|
const position = inventory.indexOf(item);
|
|||
|
|
|||
|
// exsisting item: update quantity
|
|||
|
if (position !== -1) {
|
|||
|
const row = Math.floor(position / 2);
|
|||
|
arr1[row][0] += quantity;
|
|||
|
continue;
|
|||
|
}
|
|||
|
|
|||
|
// alien item: add to inventory
|
|||
|
arr1.push([quantity, item]);
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
// sort inventory in alphabetical order
|
|||
|
arr1.sort((previous, next) => (previous[1] > [next[1]]) ? 1 : -1);
|
|||
|
|
|||
|
return arr1;
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
// test here
|
|||
|
// 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);
|
|||
|
```
|
|||
|
|
|||
|
 [Код запуска](https://repl.it/MQvv/latest)
|
|||
|
|
|||
|
### Код Объяснение:
|
|||
|
|
|||
|
* Преобразуйте текущий массив инвентаризации **arr1** в одномерный массив, чтобы `indexOf()` мог использоваться для проверки наличия новых элементов поставки в текущем инвентаре.
|
|||
|
* Проверьте, существует ли элемент в текущем инвентаре, используя `indexOf()` .
|
|||
|
* Если элемент содержит количество обновлений и выполнение цикла цикла.
|
|||
|
* Просто добавьте элемент в инвентарь.
|
|||
|
* Наконец, отсортируйте массив по алфавиту и верните обновленный инвентарь.
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [JS Function.prototype.apply ()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/apply)
|
|||
|
* [JS продолжается](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/continue)
|
|||
|
* [JS Array.prototype.sort ()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort)
|
|||
|
|
|||
|
##  ПРИМЕЧАНИЯ ДЛЯ ВЗНОСОВ:
|
|||
|
|
|||
|
*  **НЕ** добавляйте решения, похожие на любые существующие решения. Если вы считаете, что это **_похоже, но лучше_** , попробуйте объединить (или заменить) существующее подобное решение.
|
|||
|
* Добавьте объяснение своего решения.
|
|||
|
* Классифицируйте решение в одной из следующих категорий - **Basic** , **Intermediate** и **Advanced** . 
|
|||
|
* Пожалуйста, добавьте свое имя пользователя, только если вы добавили **соответствующее основное содержимое** . (  **_НЕ_** _удаляйте существующие имена пользователей_ )
|
|||
|
|
|||
|
> Видеть  [**`Wiki Challenge Solution Template`**](http://forum.freecodecamp.com/t/algorithm-article-template/14272) для [**`Wiki Challenge Solution Template`**](http://forum.freecodecamp.com/t/algorithm-article-template/14272) для справки.
|