Hi, I am not sure what's wrong with my code. Can you please check why it is giving me an error? In the starter file is a partial implementation of a doubly-linked list in DoublyLinkedList.java. We will write three new methods in this class to provide additional functionality. Write a method addFirst that adds a new element at the beginning of a DoublyLinkedList. Write a method addLast that adds a new element at the end of a DoublyLinkedList. Write a method removeFirst that removes and returns the first element of a DoublyLinkedList. Try to keep your implementations as simple as possible. For example, recall this definition of addFirst in the (Singly) LinkedList class: public void addFirst(E value) { head = new Node(value, head); } In the DoublyLinkedList class, you will need to keep the three instance variables head, tail, and count updated in all methods. Note that addFirst and addLast will be symmetric to each other, as will removeFirst and removeLast (provided in the starter code).
Hi, I am not sure what's wrong with my code. Can you please check why it is giving me an error?
In the starter file is a partial implementation of a doubly-linked list in DoublyLinkedList.java. We will write three new methods in this class to provide additional functionality.
-
Write a method addFirst that adds a new element at the beginning of a DoublyLinkedList.
-
Write a method addLast that adds a new element at the end of a DoublyLinkedList.
-
Write a method removeFirst that removes and returns the first element of a DoublyLinkedList.
Try to keep your implementations as simple as possible. For example, recall this definition of addFirst in the (Singly) LinkedList class:
public void addFirst(E value) { head = new Node(value, head); }
In the DoublyLinkedList class, you will need to keep the three instance variables head, tail, and count updated in all methods. Note that addFirst and addLast will be symmetric to each other, as will removeFirst and removeLast (provided in the starter code).
data:image/s3,"s3://crabby-images/1e3fe/1e3fec674dbbaae4db43ee68fbec68228298cfb9" alt="public class DoublyLinkedList<E> {
protected Node head;
protected Node tail;
protected int count;
public DoublyLinkedList() {
head = null;
tail = null;
count = 0;
}
public void addFirst (E value) {
Node<E> newNode = new Node<E> (value);
0) {
tail = newNode;
if (count ==
} else {
head.setPrevious (newNode);
newMode.setNext (head);
head = newNode;
count++;
}
public void addLast (E value) {
Node<E> newNode = new Node<E> (value);
if (count ==
0) {
head = newNode;
} else {
tail.setNext (newNode);
newNode.setPrevious (tail);
tail = newNode;
count++;
}
public E removeFirst() {
if (count == = 0) {
return null;
}
E value head.getValue();
if (count
== 1) {
head = null;
tail = null;
} else {
head = head.getNext();
head.setPrevious (null);"
![}
public E removeLast() {
if (tail == null) {
return null;
count--;
return value ();
}
}
else {
E returnValue = tail.value();
tail = tail.prev();
if (tail == null) {
head = null;
}
else {
}
}
tail.setNext (next:null);
public String toString() {
Node finger = head;
String result = "[ ";
while (finger != null) {
count--;
return returnValue;
result + finger.toString() +
finger = finger.next();
}
result += "]";
return result;
/**
* Returns the number of elements in this list.
*
* @return the number of elements in this list
*/
public int size() {
return count;
Run | Debug
public static void main(String[] args) {](/v2/_next/image?url=https%3A%2F%2Fcontent.bartleby.com%2Fqna-images%2Fquestion%2F385eb8fb-6648-4df6-8047-4f830c46ad3b%2Faa46f49f-369f-4595-aec3-91a4f294b95d%2F32z1txf_processed.png&w=3840&q=75)
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 7 steps with 7 images
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"