DLL Operation: Append
- 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 append (add to the end) a new node.
data:image/s3,"s3://crabby-images/ab075/ab075efaa821451abfcc1a07ec5e5fdcf887a55f" alt=""
Exercise Complete the implementation of the addLast
method that creates a node and add it to the back of the list.
public void addLast(T data) {
// TODO Implement me!
}
Hint: Use the following visualization as guidance.
data:image/s3,"s3://crabby-images/79e16/79e16691eaea4c9eeef4b53aa92447eeb9d7d9fb" alt=""
Solution
public void addLast(T data) {
Node<T> node = new Node<>(data);
node.prev = tail;
tail.next = node;
tail = node;
}
Caution: the implementation above fails to account for edge cases!