2021-06-15 00:49:18 -07:00
---
id: 587d8251367417b2b2512c63
2021-08-02 23:05:44 +09:00
title: Remover elementos de uma lista encadeada
2021-06-15 00:49:18 -07:00
challengeType: 1
forumTopicId: 301712
dashedName: remove-elements-from-a-linked-list
---
# --description--
2021-08-02 23:05:44 +09:00
O próximo método importante que qualquer implementação de uma lista encadeada precisará é de um método `remove` . Este método deve receber como argumento o elemento que queremos remover, e, em seguida, procurar na lista para encontrar e remover o nó que contém esse elemento.
2021-06-15 00:49:18 -07:00
2021-08-02 23:05:44 +09:00
Sempre que removermos um nó de uma lista encadeada, é importante que não deixemos o resto da lista órfã ao fazer isso. Lembre-se de que todos os pontos de propriedade `next` dos nós apontam para o nó que os segue na lista. Se estivermos removendo o elemento do meio, digamos, vamos precisar ter certeza de que temos uma conexão com a propriedade `next` do nó anterior daquele elemento para a propriedade `next` do elemento do meio (que é o próximo nó na lista!)
2021-06-15 00:49:18 -07:00
2021-08-02 23:05:44 +09:00
Isso pode parecer muito confuso, então vamos voltar ao exemplo da fila de dançarinos de conga para que tenhamos um bom modelo conceitual. Imagine-se em uma fila de dançarinos de conga e que a pessoa diretamente à sua frente saia da fila. A pessoa que acabou de deixar a fila já não tem as mãos sobre ninguém da fila - e você já não tem as mãos sobre a pessoa que saiu. Você dá um passo para a frente e coloca as mãos na próxima pessoa que vê.
2021-06-15 00:49:18 -07:00
2021-08-02 23:05:44 +09:00
Se o elemento que queremos remover for o elemento `head` , reatribuímos a propriedade `head` para o segundo nó da lista encadeada.
2021-06-15 00:49:18 -07:00
# --instructions--
2021-08-02 23:05:44 +09:00
Escreva um método `remove` que pegue um elemento e o remova da lista encadeada.
2021-06-15 00:49:18 -07:00
2021-08-02 23:05:44 +09:00
**Observação:** o `length` da lista deve diminuir em um sempre que um elemento for removido da lista encadeada.
2021-06-15 00:49:18 -07:00
# --hints--
2021-08-02 23:05:44 +09:00
A classe `LinkedList` deve ter o método `remove` .
2021-06-15 00:49:18 -07:00
```js
assert(
(function () {
var test = new LinkedList();
return typeof test.remove === 'function';
})()
);
```
2021-08-02 23:05:44 +09:00
O método `remove` deve reatribuir `head` ao segundo nó quando o primeiro nó for removido.
2021-06-15 00:49:18 -07:00
```js
assert(
(function () {
var test = new LinkedList();
test.add('cat');
test.add('dog');
test.remove('cat');
return test.head().element === 'dog';
})()
);
```
2021-08-02 23:05:44 +09:00
O método `remove` deve diminuir o `length` da lista encadeada em um para cada nó removido.
2021-06-15 00:49:18 -07:00
```js
assert(
(function () {
var test = new LinkedList();
test.add('cat');
test.add('dog');
test.add('hamster');
test.remove('cat');
test.remove('fish');
return test.size() === 2;
})()
);
```
2021-08-02 23:05:44 +09:00
O método `remove` deve reatribuir a referência do nó anterior ao nó removido para a referência `next` do nó removido.
2021-06-15 00:49:18 -07:00
```js
assert(
(function () {
var test = new LinkedList();
test.add('cat');
test.add('dog');
test.add('snake');
test.add('kitten');
test.remove('snake');
return test.head().next.next.element === 'kitten';
})()
);
```
2021-08-02 23:05:44 +09:00
O método `remove` não deve alterar a lista encadeada se o elemento não existir nela.
2021-06-15 00:49:18 -07:00
```js
assert(
(function () {
var test = new LinkedList();
test.add('cat');
test.add('dog');
test.add('kitten');
test.remove('elephant');
return (
JSON.stringify(test.head()) ===
'{"element":"cat","next":{"element":"dog","next":{"element":"kitten","next":null}}}'
);
})()
);
```
# --seed--
## --seed-contents--
```js
function LinkedList() {
var length = 0;
var head = null;
var Node = function(element){
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){
// Only change code below this line
// Only change code above this line
};
}
```
# --solutions--
```js
function LinkedList() {
var length = 0;
var head = null;
var Node = function(element){
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){
if (head === null) {
return;
}
var previous;
var currentNode = head;
while (currentNode.next !== null & & currentNode.element !== element) {
previous = currentNode;
currentNode = currentNode.next;
}
2021-07-09 21:23:54 -07:00
2021-06-15 00:49:18 -07:00
if (currentNode.next === null & & currentNode.element !== element) {
return;
}
else if (previous) {
previous.next = currentNode.next;
} else {
head = currentNode.next;
}
length--;
};
}
```