remove
. Этот метод должен взять элемент, который мы хотим удалить в качестве аргумента, а затем выполнить поиск в списке, чтобы найти и удалить узел, содержащий этот элемент. Всякий раз, когда мы удаляем узел из связанного списка, важно, чтобы мы не случайно оставили все остальное в списке. Напомним, что next
свойство next
узла указывает на узел, который следует за ним в списке. Если мы удалим средний элемент, скажем, мы хотим убедиться , что у нас есть связь с предыдущим узлом этого элемента next
имущества к середине элемента next
имуществу (который является следующим узлом в списке!) Это может показаться действительно запутанный, так что давайте вернемся к примеру линии conga, чтобы у нас была хорошая концептуальная модель. Представьте себя в линии конги, и человек прямо перед вами покинет линию. Лицо, которое только что покинуло линию, больше не имеет руки на кого-либо в очереди - и у вас больше нет рук на лице, которое осталось. Вы шагнете вперед и положите руки на следующего человека, которого видите. Если элемент мы хотим , чтобы удалить это head
элемент, мы переназначить head
на второй узел связанного списка. remove
который принимает элемент и удаляет его из связанного списка. Примечание. length
списка должна уменьшаться на единицу при каждом удалении элемента из связанного списка. LinkedList
должен иметь метод remove
.
testString: 'assert((function(){var test = new LinkedList(); return (typeof test.remove === "function")}()), "Your LinkedList
class should have a remove
method.");'
- text: Метод remove
должен переназначить head
во второй узел при удалении первого узла.
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.remove("cat"); return test.head().element === "dog"}()), "Your remove
method should reassign head
to the second node when the first node is removed.");'
- text: Метод remove
должен уменьшать length
связанного списка по одному на каждый удаленный узел.
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog"); test.remove("cat"); return test.size() === 1})(), "Your remove
method should decrease the length
of the linked list by one for every node removed.");'
- text: Метод remove
должен переназначить ссылку предыдущего узла удаленного узла на next
ссылку удаленного узла.
testString: 'assert((function(){var test = new LinkedList(); test.add("cat"); test.add("dog");test.add("kitten"); test.remove("dog"); return test.head().next.element === "kitten"})(), "Your remove
method should reassign the reference of the previous node of the removed node to the removed node's next
reference.");'
```