removeAt
который удаляет element
по заданному index
. Метод следует называть removeAt(index)
. Чтобы удалить element
с определенным index
, нам нужно сохранить количество запусков каждого узла при перемещении по связанному списку. Обычный метод, используемый для итерации через элементы связанного списка, включает в себя «бегун» или дозорный, который «указывает» на узлы, которые сравнивает ваш код. В нашем случае, начиная с head
нашего списка, мы начинаем с переменной currentIndex
которая начинается с 0
. currentIndex
должен увеличиваться на единицу для каждого проходящего узла. Так же, как наш метод remove(element)
, мы должны быть осторожны, чтобы не осилить остальную часть нашего списка, когда мы удаляем узел в нашем методе removeAt (index). Мы держим наши узлы смежными, убедившись, что узел, имеющий ссылку на удаленный узел, имеет ссылку на следующий узел. removeAt(index)
который удаляет и возвращает узел с заданным index
. Метод должен возвращать значение null
если данный index
либо отрицательный, либо больше или равен length
связанного списка. Примечание. Не забудьте сохранить счетчик currentIndex
. LinkedList
должен иметь removeAt
.
testString: 'assert((function(){var test = new LinkedList(); return (typeof test.removeAt === "function")}()), "Your LinkedList
class should have a removeAt
method.");'
- text: Метод removeAt
должен уменьшить length
связанного списка
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.add("kitten"); test.removeAt(1); return test.size() === 2}()), "Your removeAt
method should reduce the length
of the linked list");'
- text: Метод removeAt
также должен возвращать элемент удаленного узла.
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.add("kitten"); return test.removeAt(1) === "dog"}()), "Your removeAt
method should also return the element of the removed node.");'
- text: Метод removeAt
также должен возвращать значение null
если данный индекс меньше 0
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.add("kitten"); return (test.removeAt(-1) === null)}()), "Your removeAt
method should also return null
if the given index is less than 0
");'
- text: Метод removeAt
также должен возвращать значение null
если данный индекс равен или больше length
связанного списка.
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.add("kitten"); return (test.removeAt(3) === null)}()), "Your removeAt
method should also return null
if the given index is equal or more than the length
of the linked list.");'
```