Complete the implementations of the abstract class LinkedList.java, which implements the List.java interface and the class LinkedOrderedList.java, which extends the abstract class LinkedList.java and implements theOrderedList.java interface. LinkedList methods to implement: removeFirst removeLast remove contains LinkedOrderedList method to implement: add Recommended order of development: add to empty list to end of list to front of list to middle of list contains removeFirst removeLast remove Write a test class that tests all of the methods you implemented. Note: You only need to test LinkedOrderedList, because all of the methods are implemented in that class or inherited from LinkedList.
Complete the implementations of
- the abstract class LinkedList.java, which implements the List.java interface and
- the class LinkedOrderedList.java, which extends the abstract class LinkedList.java and implements theOrderedList.java interface.
LinkedList methods to implement:
- removeFirst
- removeLast
- remove
- contains
LinkedOrderedList method to implement:
- add
Recommended order of development:
- add
- to empty list
- to end of list
- to front of list
- to middle of list
- contains
- removeFirst
- removeLast
- remove
Write a test class that tests all of the methods you implemented. Note: You only need to test LinkedOrderedList, because all of the methods are implemented in that class or inherited from LinkedList.
Although you are not required to submit the test class, you might be asked to do so if you are having difficulties getting your implementation to work.
Submit the completed LinkedList.java and LinkedOrderedList.java.
LinkedList.java code
import java.util.NoSuchElementException;
import java.util.StringJoiner;
public abstract class LinkedList<E> implements List<E> {
protected class Node {
E element;
Node next;
Node(E element) {
this(element, null);
}
Node(E element, Node next) {
this.element = element;
this.next = next;
}
}
protected int count;
protected Node head;
protected Node tail;
/**
* Creates an empty list.
*/
public LinkedList() {
count = 0;
head = null;
tail = null;
}
/**
* Removes and returns the first element from the list.
*
* @return the first element of the list
* @throws IllegalStateException if the list is empty
*/
@Override
public E removeFirst() {
if (isEmpty()) {
throw new IllegalStateException("The LinkedList is empty.");
}
return null;
}
/**
* Removes and returns the last element from the list.
*
* @return the last element in the list
* @throws IllegalStateException if the list is empty
*/
@Override
public E removeLast() {
if (isEmpty()) {
throw new IllegalStateException("The LinkedList is empty.");
}
return null;
}
/**
* Removes and returns the specified element from the list.
*
* @param targetElement the element to be removed from the list
* @return the removed element
* @throws IllegalStateException if the list is empty
* @throws NoSuchElementException if the target element is not found
*/
@Override
public E remove(E targetElement) {
if (isEmpty()) {
throw new IllegalStateException("The LinkedList is empty.");
}
return null;
}
/**
* Returns the first element in the list without removing it.
*
* @return the first element in the list
* @throws IllegalStateException if the list is empty
*/
@Override
public E first() {
if (isEmpty()) {
throw new IllegalStateException("The LinkedList is empty.");
}
return head.element;
}
/**
* Returns the last element in the list without removing it.
*
* @return the last element in the list
* @throws IllegalStateException if the list is empty
*/
@Override
public E last() {
if (isEmpty()) {
throw new IllegalStateException("The LinkedList is empty.");
}
return tail.element;
}
/**
* Returns true if the specified element is found in the list.
*
* @param targetElement the element that is sought in the list
* @return true if the element is found in the list
* @throws IllegalStateException if the list is empty
*/
@Override
public boolean contains(E targetElement) {
if (isEmpty()) {
throw new IllegalStateException("The LinkedList is empty.");
}
return false;
}
/**
* Returns true if the list contains no elements.
*
* @return true if the list contains no elements
*/
@Override
public boolean isEmpty() {
return (count == 0);
}
/**
* Returns the number of elements in the list.
*
* @return the number of elements in the list
*/
@Override
public int size() {
return count;
}
/**
* Returns a string representation of the list.
*
* @return a string representation of the list
*/
@Override
public String toString() {
StringJoiner result = new StringJoiner(", ", "[", "]");
Node current = head;
while (current != null) {
result.add(current.element.toString());
current = current.next;
}
return result.toString();
}
}
Thank you for any help/suggestions!
data:image/s3,"s3://crabby-images/b96fb/b96fb74c2862cc6134cf76e9ed9d957b3e9b6e0b" alt="*/
public class LinkedOrdered List<E> extends LinkedList<E> implements Ordered List<E> {
/**
* Creates an empty list.
*/
public LinkedOrdered List() {
super();
}
/**
* Adds the specified element to this list at the location determined by
* the element's natural ordering.
*
* @param element the element to be added to this list
* @throws IllegalStateException if the element is not of a Comparable type
*/
@Override
public void add (E element) {
if (!(element instanceof Comparable)) {
throw new IllegalStateException ("LinkedOrdered List requires Comparable elements.");
}
var comparableElement = (Comparable<E>) element;"
data:image/s3,"s3://crabby-images/38cd9/38cd9825b5c53574251ddda70e0cb2179c8240e5" alt="public interface List<E> {
/**
* Removes and returns the first element from the list.
}
*
* @return the first element of the list
*/
public E removeFirst();
/**
* Removes and returns the last element from the list.
*
* @return the last element in the list
*/
public E removeLast();
/**
* Removes and returns the specified element from the list.
*
* @param targetElement the element to be removed from the list
* @return the removed element
*/
public E remove(E element);
/**
* Returns the first element in the list without removing it.
*
* @return the first element in the list
*/
public E first();
/**
* Returns the last element in the list without removing it.
*
* @return the last element in the list
*/
public E last();
/**
* Returns true if the specified element is found in the list.
*
* @param targetElement the element that is sought in the list
* @return true if the element is found in the list
*/
public boolean contains (E targetElement);
/**
* Returns true if the list contains no elements.
*
* @return true if the list contains no elements
*/
public boolean isEmpty();
/**
* Returns the number of elements in the list.
*
* @return number of elements in the list
*/
public int size();
/**
* Returns a string representation of the list.
*
* @return a string representation of the list
*/
public String toString();"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 4 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"