Given a singly linked list, find the middle of the linked list. For example, if the given linked list is 1->2->3->4->5 then the output should be 3. If there are even nodes, then there would be two middle nodes, we need to print the second middle element. For example, if given linked list is 1 >2->3->4->5->6 then the output should be 4. Make the following adjustments to the class HWLinkedList  code below Add the method addAtHead to the class below. The method should simply add a new element to the beginning of the linked list instead of the end. Add the method searchList to the class below. The method should return true if the user specified object is found and false otherwise. The method must be recursive. Add the remove method   public class HWLinkedList<E> { private class Node<E> { private E data; Node<E> next; public Node(E data) { this.data = data; this.next = null; } } private Node<E> head; public HWLinkedList() { this.head = null; } private String toString (Node<E> head) { if (head == null) return””; return head.data.toString() + “\n” + toString(head.next); } public String toString() { return toString(head); } private void add(Node<E> head, E data) { if (head.next == null) head.next = new Node<E>(data); else add(head.next, data) } public void add(E data) { if (head == null) head = new Node<E>(data); else add(head, data); } }

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

 

Given a singly linked list, find the middle of the linked list. For example, if the given linked list is 1->2->3->4->5 then the output should be 3. If there are even nodes, then there would be two middle nodes, we need to print the second middle element. For example, if given linked list is 1 >2->3->4->5->6 then the output should be 4.

Make the following adjustments to the class HWLinkedList  code below

  1. Add the method addAtHead to the class below. The method should simply add a new

element to the beginning of the linked list instead of the end.

  1. Add the method searchList to the class below. The method should return true if the user

specified object is found and false otherwise. The method must be recursive.

  1. Add the remove method

 

public class HWLinkedList<E>

{

private class Node<E>

{

private E data;

Node<E> next;

public Node(E data)

{

this.data = data;

this.next = null;

}

}

private Node<E> head;

public HWLinkedList()

{

this.head = null;

}

private String toString (Node<E> head)

{

if (head == null)

return””;

return head.data.toString() + “\n” + toString(head.next);

}

public String toString()

{

return toString(head);

}

private void add(Node<E> head, E data)

{

if (head.next == null)

head.next = new Node<E>(data);

else

add(head.next, data)

}

public void add(E data)

{

if (head == null)

head = new Node<E>(data);

else

add(head, data);

}

}

 

AI-Generated Solution
AI-generated content may present inaccurate or offensive content that does not represent bartleby’s views.
steps

Unlock instant AI solutions

Tap the button
to generate a solution

Knowledge Booster
Operations of Linked List
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
  • SEE MORE QUESTIONS
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education