6.6 KiB
title, localeTitle
| title | localeTitle |
|---|---|
| Slice and Splice | Нарезка и сращивание |
Нарезка и сращивание
Не забудьте использовать Read-Search-Ask если вы застряли. Попробуйте подключить программу
и напишите свой собственный код 
Проблема Объяснение:
Нам нужно скопировать каждый элемент из первого массива во второй массив, начиная с индекса n. Мы также должны убедиться, что исходные массивы не мутированы. То есть мы не можем внести никаких изменений в исходные массивы.
Связанные ссылки
Подсказка: 1
Создайте копию второго массива внутри функции. Это гарантирует, что исходный массив не будет мутирован. Это можно сделать, используя операцию среза во втором массиве и присвоить его переменной.
попытаться решить проблему сейчас
Подсказка: 2
Прокрутите все элементы в первом массиве. Для каждого элемента в первом массиве сплайсируйте его в скопированный массив в указателе, указанном в качестве аргумента.
попытаться решить проблему сейчас
Подсказка: 3
Увеличьте индекс после выполнения сращивания.
попытаться решить проблему сейчас
Осторожно, спойлеры!
Решение впереди!
Решение базового кода:
function frankenSplice(arr1, arr2, n) {
// It's alive. It's alive!
let localArray = arr2.slice();
for (let i = 0; i < arr1.length; i++) {
localArray.splice(n, 0, arr1[i]);
n++;
}
return localArray;
}
Код Объяснение:
-
Наша цель - взять все элементы из
arr1и вставить их вarr2начиная с позиции индексаn. В то же время мы должны гарантировать, что ниarrниarr2не были мутированы. -
Используя функцию
slice()мы можем создать точную репликаarr2и присвоить результат операции переменнойlocalArray. -
Теперь, когда у нас есть массив, с которым мы можем мутировать, мы можем перебирать каждый элемент в первом массиве. Для каждого элемента в первом массиве мы можем использовать функцию
splice()чтобы вставить элемент в индексnlocalArray. -
Мы увеличиваем индекс
nна единицу. Это гарантирует, что каждый элемент изarr1будет вставлен вlocalArrayв правильное положение индекса. -
Наконец, мы возвращаем
localArrayиlocalArrayфункцию.
ПРИМЕЧАНИЯ ДЛЯ ВЗНОСОВ:
НЕ добавляйте решения, похожие на любые существующие решения. Если вы считаете, что это похоже, но лучше , попробуйте объединить (или заменить) существующее подобное решение.- Добавьте объяснение своего решения.
- Классифицируйте решение в одной из следующих категорий - Basic , Intermediate и Advanced .

- Пожалуйста, добавьте свое имя пользователя, только если вы добавили соответствующее основное содержимое . (
НЕ удаляйте существующие имена пользователей )
Увидеть
![]()
Wiki Challenge Solution TemplateдляWiki Challenge Solution Templateдля справки.


