6.6 KiB
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()
чтобы вставить элемент в индексn
localArray
. -
Мы увеличиваем индекс
n
на единицу. Это гарантирует, что каждый элемент изarr1
будет вставлен вlocalArray
в правильное положение индекса. -
Наконец, мы возвращаем
localArray
иlocalArray
функцию.
ПРИМЕЧАНИЯ ДЛЯ ВЗНОСОВ:
- НЕ добавляйте решения, похожие на любые существующие решения. Если вы считаете, что это похоже, но лучше , попробуйте объединить (или заменить) существующее подобное решение.
- Добавьте объяснение своего решения.
- Классифицируйте решение в одной из следующих категорий - Basic , Intermediate и Advanced .
- Пожалуйста, добавьте свое имя пользователя, только если вы добавили соответствующее основное содержимое . ( НЕ удаляйте существующие имена пользователей )
Увидеть
Wiki Challenge Solution Template
дляWiki Challenge Solution Template
для справки.