Data Structures and Algorithms in Java
Data Structures and Algorithms in Java
6th Edition
ISBN: 9781119278023
Author: Michael T. Goodrich; Roberto Tamassia; Michael H. Goldwasser
Publisher: Wiley Global Education US
Expert Solution & Answer
Book Icon
Chapter 3, Problem 31C

Explanation of Solution

Reimplementation of DoublyLinkedList class using only one sentinel node:

The doubly linked list is a linked data structure which contains the collection of sequentially data with two sentinel nodes such as “header” and “trailer”.

  • If there is only one sentinel node, then the list is circularly linked using sentinel node.
  • That is, header is sentinel node means, the next of the header is first node of list and previous node of header is last node of list.

Code for DoublyLinkedList class using only one sentinel node:

//Define the DoublyLinkedList class

public class DoublyLinkedList<E>

{

  //Declare only one sentinel node

private Node<E> header;

  //Declare and initialize the "size" variable

private int size = 0;

/*Define the Constructor to construct a new empty list. */

  public DoublyLinkedList()

  {

//Create header sentinel

header = new Node<>(null, null, null);

  }

//Define the size() method

  public int size()

  {

/*Returns the number of elements in the linked list. */

  return size;

  }

  //Define isEmpty() method

  public boolean isEmpty()

  {

  //Check whether the linked list is empty

  return size == 0;

  }

//Define first() method

  public E first()

  {

  //Check whether the list is empty

  if(isEmpty())

  //Return null

  return null;

//Returns the first element of the list

  return header.getNext().getElement();

  }

//Define last() method

  public E last( )

  {

  //Check whether the list is empty

  if(isEmpty())

  //Return null

  return null;

/*Returns the last element of the list using the single sentinel node "header". */

  return header.getPrev().getElement( );

  }

  //Define addFirst() method

  public void addFirst(E e)

  {

/*Call addBetween() method to adds element "e" to the front of the list. */

  addBetween(e, header, header.getNext

  }

  /Define the addLast() method

  public void addLast(E e)

  {

/*Call addBetween() method to adds element e to the end of the list using single sentinel node "header". */

  addBetween(e, header.getPrev(), header);

  }

//Define the removeFirst() method

  public E removeFirst()

  {

  //Check whether the list is empty

  if (isEmpty())

  //Return null

  return null;

/*Call remove() method to removes and returns the first element of the list. */

  return remove(header...

Blurred answer
Students have asked these similar questions
Consider the following database for some store: Customers (cid, cname, city, discount)Agents (aid, aname, city, percent)Products (pid, pname, city, quantity, price)Orders (ordno, mon, cid, aid, pid, qty, dollars) The relation Customers records the ID (cid), name (cname), location (city) of each customer and a discount percentage (discount) for this customer. The relation Agents records the ID (aid), name (aname), location (city) of each agent and a transaction fee (percent) charged by this agent. The relation Products lists the ID (pid), name (pname), location (city), quantity and price of available products. And finally, the relation Orders contains a unique order number (ordno), the month (mon), customer (cid), agent (aid), product (pid), quantity (qty) of each order as well as the total value (dollars) of the transaction.   1. Express the following query in SQL (a) List customers (names) who do not have discounts but purchased at least one product of price greater than $50. (b) Find…
Consider the following relational schema and briefly answer the questions that follow:   Emp(eid: integer, ename: string, age: integer, salary: real)  Works(eid: integer, did: integer, pct_time: integer)  Dept(did: integer, budget: real, managerid: integer)      a. Define a table constraint on Dept that will ensure that all managers have age > 30. b. Write SQL statements to delete all information about employees whose salaries exceed that of the manager of one or more departments that they work in. Be sure to ensure that all the relevant integrity constraints are satisfied after your updates.
Consider the following relations:     Student(snum: integer, sname: string, rmajor: string,          level: string, age: integer)   Class(cname: string, meets_at: time, room: string, fid: integer)   Enrolled(snum: integer, cname: string)   Faculty(fid: integer, fname: string, deptid: integer)     The meaning of these relations is straightforward; for example, Enrolled has one record per student-class pair such that the student is enrolled in the class.     2. Express each of the following integrity constraints in SQL unless it is implied by the primary and foreign key constraint; if so, explain how it is implied. If the constraint cannot be expressed in SQL, say so. For each constraint, state what operations (inserts, deletes, and updates on specific relations) must be monitored to enforce the constraint.   (a) Every faculty member must teach at least two courses. (b) Every student must be enrolled in the course called 'Math101'. (c) A student cannot add more than two courses at a time…
Knowledge Booster
Background pattern image
Similar questions
SEE MORE QUESTIONS
Recommended textbooks for you
Text book image
C++ Programming: From Problem Analysis to Program...
Computer Science
ISBN:9781337102087
Author:D. S. Malik
Publisher:Cengage Learning
Text book image
EBK JAVA PROGRAMMING
Computer Science
ISBN:9781337671385
Author:FARRELL
Publisher:CENGAGE LEARNING - CONSIGNMENT
Text book image
New Perspectives on HTML5, CSS3, and JavaScript
Computer Science
ISBN:9781305503922
Author:Patrick M. Carey
Publisher:Cengage Learning
Text book image
Systems Architecture
Computer Science
ISBN:9781305080195
Author:Stephen D. Burd
Publisher:Cengage Learning
Text book image
C++ for Engineers and Scientists
Computer Science
ISBN:9781133187844
Author:Bronson, Gary J.
Publisher:Course Technology Ptr
Text book image
Microsoft Visual C#
Computer Science
ISBN:9781337102100
Author:Joyce, Farrell.
Publisher:Cengage Learning,