DLL Operation: Delete
- Trace the basic operations of a (doubly) linked-list implementation.
- Understand the basic operations of a (doubly) linked list well enough to implement them.
Suppose we want to delete the node pointed to by the reference variable target
:
data:image/s3,"s3://crabby-images/e3784/e3784060391ddade39ae683a6bfa7a1d3583e26b" alt=""
Exercise Complete the implementation of delete
.
public void delete(Node<T> target) {
// TODO Implement me!
}
Hint: Use the following visualization as guidance.
data:image/s3,"s3://crabby-images/1f923/1f923b15291259c5641722d3dfb58dd644c5d46c" alt=""
Solution
public void delete(Node<T> target) {
Node<T> prevNode = target.prev;
Node<T> nextNode = target.next;
prevNode.next = nextNode;
nextNode.prev = prevNode;
// no need for these!
target.next = null;
target.prev = null;
}
Caution: the implementation above fails to account for edge cases!