DLL Operation: Prepend
- 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 have the following DLL, and we want to add a new node to its front.
data:image/s3,"s3://crabby-images/43e6f/43e6f4e21d5b0dbd1db6d6941f56744294ca8d29" alt=""
Exercise Complete the implementation of the addFirst
method that creates a node and adds it to the front of the list.
public void addFirst (T data) {
// TODO Implement Me!
}
Hint: Use the following visualization as a guidance:
data:image/s3,"s3://crabby-images/f9e3a/f9e3ad4ac5dd694b32a81a7e8bb0a18954855ff0" alt=""
Solution
public void addFirst(T data) {
Node<T> node = new Node<>(data);
node.next = head;
head.prev = node;
head = node;
}
Caution: the implementation above fails to account for edge cases!