112 lines
6.0 KiB
Markdown
112 lines
6.0 KiB
Markdown
|
---
|
|||
|
id: 587d8251367417b2b2512c65
|
|||
|
title: Remove Elements from a Linked List by Index
|
|||
|
challengeType: 1
|
|||
|
videoUrl: ''
|
|||
|
localeTitle: Удалить элементы из связанного списка по индексу
|
|||
|
---
|
|||
|
|
|||
|
## Description
|
|||
|
<section id="description"> Прежде чем перейти к другой структуре данных, давайте получим пару последних бит практики со связанными списками. Давайте напишем <code>removeAt</code> который удаляет <code>element</code> по заданному <code>index</code> . Метод следует называть <code>removeAt(index)</code> . Чтобы удалить <code>element</code> с определенным <code>index</code> , нам нужно сохранить количество запусков каждого узла при перемещении по связанному списку. Обычный метод, используемый для итерации через элементы связанного списка, включает в себя <dfn>«бегун»</dfn> или дозорный, который «указывает» на узлы, которые сравнивает ваш код. В нашем случае, начиная с <code>head</code> нашего списка, мы начинаем с переменной <code>currentIndex</code> которая начинается с <code>0</code> . <code>currentIndex</code> должен увеличиваться на единицу для каждого проходящего узла. Так же, как наш метод <code>remove(element)</code> , мы должны быть осторожны, чтобы не осилить остальную часть нашего списка, когда мы удаляем узел в нашем методе removeAt (index). Мы держим наши узлы смежными, убедившись, что узел, имеющий ссылку на удаленный узел, имеет ссылку на следующий узел. </section>
|
|||
|
|
|||
|
## Instructions
|
|||
|
<section id="instructions"> Напишите <code>removeAt(index)</code> который удаляет и возвращает узел с заданным <code>index</code> . Метод должен возвращать значение <code>null</code> если данный <code>index</code> либо отрицательный, либо больше или равен <code>length</code> связанного списка. Примечание. Не забудьте сохранить счетчик <code>currentIndex</code> . </section>
|
|||
|
|
|||
|
## Tests
|
|||
|
<section id='tests'>
|
|||
|
|
|||
|
```yml
|
|||
|
tests:
|
|||
|
- text: Класс <code>LinkedList</code> должен иметь <code>removeAt</code> .
|
|||
|
testString: 'assert((function(){var test = new LinkedList(); return (typeof test.removeAt === "function")}()), "Your <code>LinkedList</code> class should have a <code>removeAt</code> method.");'
|
|||
|
- text: Метод <code>removeAt</code> должен уменьшить <code>length</code> связанного списка
|
|||
|
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.add("kitten"); test.removeAt(1); return test.size() === 2}()), "Your <code>removeAt</code> method should reduce the <code>length</code> of the linked list");'
|
|||
|
- text: Метод <code>removeAt</code> также должен возвращать элемент удаленного узла.
|
|||
|
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.add("kitten"); return test.removeAt(1) === "dog"}()), "Your <code>removeAt</code> method should also return the element of the removed node.");'
|
|||
|
- text: Метод <code>removeAt</code> также должен возвращать значение <code>null</code> если данный индекс меньше <code>0</code>
|
|||
|
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.add("kitten"); return (test.removeAt(-1) === null)}()), "Your <code>removeAt</code> method should also return <code>null</code> if the given index is less than <code>0</code>");'
|
|||
|
- text: Метод <code>removeAt</code> также должен возвращать значение <code>null</code> если данный индекс равен или больше <code>length</code> связанного списка.
|
|||
|
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.add("kitten"); return (test.removeAt(3) === null)}()), "Your <code>removeAt</code> method should also return <code>null</code> if the given index is equal or more than the <code>length</code> of the linked list.");'
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
</section>
|
|||
|
|
|||
|
## Challenge Seed
|
|||
|
<section id='challengeSeed'>
|
|||
|
|
|||
|
<div id='js-seed'>
|
|||
|
|
|||
|
```js
|
|||
|
function LinkedList() {
|
|||
|
var length = 0;
|
|||
|
var head = null;
|
|||
|
|
|||
|
var Node = function(element){ // {1}
|
|||
|
this.element = element;
|
|||
|
this.next = null;
|
|||
|
};
|
|||
|
|
|||
|
this.size = function(){
|
|||
|
return length;
|
|||
|
};
|
|||
|
|
|||
|
this.head = function(){
|
|||
|
return head;
|
|||
|
};
|
|||
|
|
|||
|
this.add = function(element){
|
|||
|
var node = new Node(element);
|
|||
|
if(head === null){
|
|||
|
head = node;
|
|||
|
} else {
|
|||
|
currentNode = head;
|
|||
|
|
|||
|
while(currentNode.next){
|
|||
|
currentNode = currentNode.next;
|
|||
|
}
|
|||
|
|
|||
|
currentNode.next = node;
|
|||
|
}
|
|||
|
|
|||
|
length++;
|
|||
|
};
|
|||
|
|
|||
|
this.remove = function(element){
|
|||
|
var currentNode = head;
|
|||
|
var previousNode;
|
|||
|
if(currentNode.element === element){
|
|||
|
head = currentNode.next;
|
|||
|
} else {
|
|||
|
while(currentNode.element !== element) {
|
|||
|
previousNode = currentNode;
|
|||
|
currentNode = currentNode.next;
|
|||
|
}
|
|||
|
|
|||
|
previousNode.next = currentNode.next;
|
|||
|
}
|
|||
|
|
|||
|
length --;
|
|||
|
};
|
|||
|
|
|||
|
// Only change code below this line
|
|||
|
|
|||
|
// Only change code above this line
|
|||
|
}
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
</div>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
</section>
|
|||
|
|
|||
|
## Solution
|
|||
|
<section id='solution'>
|
|||
|
|
|||
|
```js
|
|||
|
// solution required
|
|||
|
```
|
|||
|
</section>
|