DLL Operation: Insert Before
- 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 insert a note before the one pointed to by the reference variable target
:
data:image/s3,"s3://crabby-images/86dcd/86dcd800e3439338a48e3ca0c4cb9d38de79b225" alt=""
Exercise Complete the implementation of insertBefore
.
public void insertBefore(Node<T> target, T data) {
// TODO Implement me!
}
Hint: Use the following visualization as guidance.
data:image/s3,"s3://crabby-images/4b2d7/4b2d7060358eaef6ddedd529d707d4a56dd7c366" alt=""
Solution
public void insertBefore(Node<T> target, T data) {
Node<T> nodeToInsert = new Node<>(data);
Node<T> prevNode = target.prev;
target.prev = nodeToInsert;
nodeToInsert.next = target;
nodeToInsert.prev = prevNode;
prevNode.next = nodeToInsert;
}
Caution: the implementation above fails to account for edge cases!