Java Programming language Help please.
Java
Help please.
data:image/s3,"s3://crabby-images/b1c11/b1c11f55833ab9adcb35b505c4c4f91c69395f7a" alt="46
47
48
49
50
51
52
public E removeFirst() {
if (isEmpty()) return null;
E answer = head.getElement();
head.getNext();
head =
53
54 }
55 }
size--;
if (size
0)
tail = null;
return answer;
==
// removes and returns the first element
// nothing to remove
// will become null if list had only one node
// special case as list is now empty"
data:image/s3,"s3://crabby-images/a6b3e/a6b3e98fc43103d8d38757e6881d712512fcae1b" alt="The removeFirst method of the SinglyLinked List class includes a special case to
reset the tail field to null when deleting the last node of a list (see lines 51 and 52
of Code Fragment 3.15). What are the consequences if we were to remove those
two lines from the code? Explain why the class would or would not work with
such a modification."
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
1 public class SinglyLinked List<E>
{
(nested Node class goes here)
......
14
15 // instance variables of the SinglyLinked List private Node<E> head = null;
private Node<E> tail = null; private int size = 0;
16 // head node of the list (or null if empty) last node of the list (or null if empty) number of nodes in the list
17 // constructs an initially empty list public SinglyLinkedList()
{
}
// access methods public int size()
{
return size;
}
public boolean isEmpty()
{
return size == 0;
}
public E first()
{
// returns (but does not remove) the first element
if (isEmpty()) return null;
24 return head.getElement();
}
public E last()
{
// returns (but does not remove) the last element
if (isEmpty())
return null;
28 return tail.getElement();
}
// update methods public void addFirst(E e)
{
head = new Node<>(e, head); 0)
// adds element e to the front of the list create and link a new node
if (size == tail = head;
// special case: new node becomes tail also size++;
36
}
37
38 public void add Last(E e)
{
// adds element e to the end of the list
Node<E> newest = new Node<>(e, null);
// node will eventually be the tail
if (isEmpty())
39
40 head newest;
// special case: previously empty list
41
else
42
tail.setNext(newest);
new node after existing tail
43 tail newest;
// new node becomes the tail
44
size++;
45
}
46 public E removeFirst()
{
// removes and returns the first element
// nothing to remove
47
if (isEmpty())
return null;
E answer = head.getElement();
48 head.getNext();
// will become null
if list had only one node size--; == 0)
if (size)
tail = null;
// special case as list is now empty
return answer;
}
}
Step by step
Solved in 2 steps
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"