--- id: 587d8251367417b2b2512c65 title: Remove Elements from a Linked List by Index challengeType: 1 videoUrl: '' localeTitle: Удалить элементы из связанного списка по индексу --- ## Description
Прежде чем перейти к другой структуре данных, давайте получим пару последних бит практики со связанными списками. Давайте напишем removeAt который удаляет element по заданному index . Метод следует называть removeAt(index) . Чтобы удалить element с определенным index , нам нужно сохранить количество запусков каждого узла при перемещении по связанному списку. Обычный метод, используемый для итерации через элементы связанного списка, включает в себя «бегун» или дозорный, который «указывает» на узлы, которые сравнивает ваш код. В нашем случае, начиная с head нашего списка, мы начинаем с переменной currentIndex которая начинается с 0 . currentIndex должен увеличиваться на единицу для каждого проходящего узла. Так же, как наш метод remove(element) , мы должны быть осторожны, чтобы не осилить остальную часть нашего списка, когда мы удаляем узел в нашем методе removeAt (index). Мы держим наши узлы смежными, убедившись, что узел, имеющий ссылку на удаленный узел, имеет ссылку на следующий узел.
## Instructions
Напишите removeAt(index) который удаляет и возвращает узел с заданным index . Метод должен возвращать значение null если данный index либо отрицательный, либо больше или равен length связанного списка. Примечание. Не забудьте сохранить счетчик currentIndex .
## Tests
```yml tests: - text: Класс 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.");' ```
## Challenge 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 { var 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 } ```
## Solution
```js // solution required ```