DLL Operation: Insert After
- 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 node after the one pointed to by the reference variable target
:
data:image/s3,"s3://crabby-images/9efd4/9efd40c0b43cb6a4d77096bfb1f6972c8474d786" alt=""
Exercise Complete the implementation of insertAfter
.
public void insertAfter(Node<T> target, T data) {
// TODO Implement me!
}
Hint: Use the following visualization as guidance.
data:image/s3,"s3://crabby-images/58fd7/58fd7edd1c47b36a13ff6bf7b2e8104aa8e85d4a" alt=""
Solution
public void insertAfter(Node<T> target, T data) {
Node<T> nodeToInsert = new Node<>(data);
Node<T> nextNode = target.next;
target.next = nodeToInsert;
nodeToInsert.prev = target;
nodeToInsert.next = nextNode;
nextNode.prev = nodeToInsert;
}
Caution: the implementation above fails to account for edge cases!