Academic Integrity: tutoring, explanations, and feedback — we don’t complete graded work or submit on a student’s behalf.

Java doubly-link list I\'m woking on my doubly-link list. I have pretty much all

ID: 3558628 • Letter: J

Question

Java doubly-link list

I'm woking on my doubly-link list. I have pretty much all the methods but im having trouble with the last three methods. Please help

/**
* LinkedList class implements a doubly-linked list.
*/
public class MyLinkedList implements Iterable
{
    /**
     * Construct an empty LinkedList.
     */
    public MyLinkedList( )
    {
        doClear( );
    }
  
    private void clear( )
    {
        doClear( );
    }
  
    /**
     * Change the size of this collection to zero.
     */
    public void doClear( )
    {
        beginMarker = new Node( null, null, null );
        endMarker = new Node( null, beginMarker, null );
        beginMarker.next = endMarker;
      
        theSize = 0;
        modCount++;
    }
  
    /**
     * Returns the number of items in this collection.
     * @return the number of items in this collection.
     */
    public int size( )
    {
        return theSize;
    }
  
    public boolean isEmpty( )
    {
        return size( ) == 0;
    }
  
    /**
     * Adds an item to this collection, at the end.
     * @param x any object.
     * @return true.
     */
    public boolean add( AnyType x )
    {
        add( size( ), x );
        return true;       
    }
  
    /**
     * Adds an item to this collection, at specified position.
     * Items at or after that position are slid one position higher.
     * @param x any object.
     * @param idx position to add at.
     * @throws IndexOutOfBoundsException if idx is not between 0 and size(), inclusive.
     */
    public void add( int idx, AnyType x )
    {
        addBefore( getNode( idx, 0, size( ) ), x );
    }
  
    /**
     * Adds an item to this collection, at specified position p.
     * Items at or after that position are slid one position higher.
     * @param p Node to add before.
     * @param x any object.
     * @throws IndexOutOfBoundsException if idx is not between 0 and size(), inclusive.
     */  
    private void addBefore( Node p, AnyType x )
    {
        Node newNode = new Node( x, p.prev, p );
        newNode.prev.next = newNode;
        p.prev = newNode;       
        theSize++;
        modCount++;
    }
  
  
    /**
     * Returns the item at position idx.
     * @param idx the index to search in.
     * @throws IndexOutOfBoundsException if index is out of range.
     */
    public AnyType get( int idx )
    {
        return getNode( idx ).data;
    }
      
  
    public void reverse()
    {
       if (theSize < 2)
          return;
        
       Node p1, p2, p3;
     
       p1 = null;
       p2 = beginMarker;
       p3 = beginMarker.next;
     
       while (p3 != null)
       {
          p2.next = p1;
          p1 = p2;
          p2 = p3;
          p3 = p3.next;
       }
     
       p2.next = p1;
     
       endMarker = beginMarker;
       beginMarker = p2;
  
    }
    /**
     * Changes the item at position idx.
     * @param idx the index to change.
     * @param newVal the new value.
     * @return the old value.
     * @throws IndexOutOfBoundsException if index is out of range.
     */
    public AnyType set( int idx, AnyType newVal )
    {
        Node p = getNode( idx );
        AnyType oldVal = p.data;
      
        p.data = newVal;
        return oldVal;
    }
  
    /**
     * Gets the Node at position idx, which must range from 0 to size( ) - 1.
     * @param idx index to search at.
     * @return internal node corresponding to idx.
     * @throws IndexOutOfBoundsException if idx is not between 0 and size( ) - 1, inclusive.
     */
    private Node getNode( int idx )
    {
        return getNode( idx, 0, size( ) - 1 );
    }

    /**
     * Gets the Node at position idx, which must range from lower to upper.
     * @param idx index to search at.
     * @param lower lowest valid index.
     * @param upper highest valid index.
     * @return internal node corresponding to idx.
     * @throws IndexOutOfBoundsException if idx is not between lower and upper, inclusive.
     */  
    private Node getNode( int idx, int lower, int upper )
    {
        Node p;
      
        if( idx < lower || idx > upper )
            throw new IndexOutOfBoundsException( "getNode index: " + idx + "; size: " + size( ) );
          
        if( idx < size( ) / 2 )
        {
            p = beginMarker.next;
            for( int i = 0; i < idx; i++ )
                p = p.next;          
        }
        else
        {
            p = endMarker;
            for( int i = size( ); i > idx; i-- )
                p = p.prev;
        }
      
        return p;
    }
  
    /**
     * Removes an item from this collection.
     * @param idx the index of the object.
     * @return the item was removed from the collection.
     */
    public AnyType remove( int idx )
    {
        return remove( getNode( idx ) );
    }
  
    /**
     * Removes the object contained in Node p.
     * @param p the Node containing the object.
     * @return the item was removed from the collection.
     */
    private AnyType remove( Node p )
    {
        p.next.prev = p.prev;
        p.prev.next = p.next;
        theSize--;
        modCount++;
      
        return p.data;
    }
  
  

    /**
     * Returns a String representation of this collection.
     */
    public String toString( )
    {
        StringBuilder sb = new StringBuilder( "[ " );

        for( AnyType x : this )
            sb.append( x + " " );
        sb.append( "]" );

        return new String( sb );
    }

    /**
     * Obtains an Iterator object used to traverse the collection.
     * @return an iterator positioned prior to the first element.
     */
    public java.util.Iterator iterator( )
    {
        return new LinkedListIterator( );
    }

    /**
     * This is the implementation of the LinkedListIterator.
     * It maintains a notion of a current position and of
     * course the implicit reference to the MyLinkedList.
     */
    private class LinkedListIterator implements java.util.Iterator
    {
        private Node current = beginMarker.next;
        private int expectedModCount = modCount;
        private boolean okToRemove = false;
      
        public boolean hasNext( )
        {
            return current != endMarker;
        }
      
        public AnyType next( )
        {
            if( modCount != expectedModCount )
                throw new java.util.ConcurrentModificationException( );
            if( !hasNext( ) )
                throw new java.util.NoSuchElementException( );
                 
            AnyType nextItem = current.data;
            current = current.next;
            okToRemove = true;
            return nextItem;
        }
      
        public void remove( )
        {
            if( modCount != expectedModCount )
                throw new java.util.ConcurrentModificationException( );
            if( !okToRemove )
                throw new IllegalStateException( );
              
            MyLinkedList.this.remove( current.prev );
            expectedModCount++;
            okToRemove = false;     
        }
    }
  
    /**
     * This is the doubly-linked list node.
     */
    private static class Node
    {
        public Node( AnyType d, Node p, Node n )
        {
            data = d; prev = p; next = n;
        }
      
        public AnyType data;
        public Node   prev;
        public Node   next;
    }
  
    private int theSize;
    private int modCount = 0;
    private Node beginMarker;
    private Node endMarker;
}

class TestLinkedList
{
    public static void main( String [ ] args )
    {
        MyLinkedList lst = new MyLinkedList( );

        for( int i = 0; i < 10; i++ )
                lst.add( i );
        for( int i = 20; i < 30; i++ )
                lst.add( 0, i );
       
        System.out.println(lst);
        lst.reverse();
        System.out.println(lst);
        lst.reverse();
        System.out.println(lst);
        lst.remove( 0 );
        lst.remove( lst.size( ) - 1 );

        System.out.println( lst );

        java.util.Iterator itr = lst.iterator( );
        while( itr.hasNext( ) )
        {
                itr.next( );
                itr.remove( );
                System.out.println( lst );
        }
    }
}

Explanation / Answer

/**

* LinkedList class implements a doubly-linked list.

*/

public class MyLinkedList<AnyType> implements Iterable<AnyType>

{

/**

* Construct an empty LinkedList.

*/

public MyLinkedList( )

{

doClear( );

}

private void clear( )

{

doClear( );

}

/**

* Change the size of this collection to zero.

*/

public void doClear( )

{

beginMarker = new Node( null, null, null );

endMarker = new Node( null, beginMarker, null );

beginMarker.next = endMarker;

theSize = 0;

modCount++;

}

/**

* Returns the number of items in this collection.

* @return the number of items in this collection.

*/

public int size( )

{

return theSize;

}

public boolean isEmpty( )

{

return size( ) == 0;

}

/**

* Adds an item to this collection, at the end.

* @param x any object.

* @return true.

*/

public boolean add( AnyType x )

{

add( size( ), x );

return true;

}

/**

* Adds an item to this collection, at specified position.

* Items at or after that position are slid one position higher.

* @param x any object.

* @param idx position to add at.

* @throws IndexOutOfBoundsException if idx is not between 0 and size(), inclusive.

*/

public void add( int idx, AnyType x )

{

addBefore( getNode( idx, 0, size( ) ), x );

}

/**

* Adds an item to this collection, at specified position p.

* Items at or after that position are slid one position higher.

* @param p Node to add before.

* @param x any object.

* @throws IndexOutOfBoundsException if idx is not between 0 and size(), inclusive.

*/

private void addBefore( Node p, AnyType x )

{

Node newNode = new Node( x, p.prev, p );

newNode.prev.next = newNode;

p.prev = newNode;

theSize++;

modCount++;

}

/**

* Returns the item at position idx.

* @param idx the index to search in.

* @throws IndexOutOfBoundsException if index is out of range.

*/

public AnyType get( int idx )

{

return getNode( idx ).data;

}

public void reverse()

{

if (theSize < 2)

return;

Node p1, p2, p3;

p1 = null;

p2 = beginMarker;

p3 = beginMarker.next;

while (p3 != null)

{

p2.next = p1;

p1 = p2;

p2 = p3;

p3 = p3.next;

}

p2.next = p1;

endMarker = beginMarker;

public void swap(int index1, int index2)

{

}

/**

* Changes the item at position idx.

* @param idx the index to change.

* @param newVal the new value.

* @return the old value.

* @throws IndexOutOfBoundsException if index is out of range.

*/

public AnyType set( int idx, AnyType newVal )

{

Node p = getNode( idx );

AnyType oldVal = p.data;

p.data = newVal;

return oldVal;

}

/**

* Gets the Node at position idx, which must range from 0 to size( ) - 1.

* @param idx index to search at.

* @return internal node corresponding to idx.

* @throws IndexOutOfBoundsException if idx is not between 0 and size( ) - 1, inclusive.

*/

private Node getNode( int idx )

{

return getNode( idx, 0, size( ) - 1 );

}

/**

* Gets the Node at position idx, which must range from lower to upper.

* @param idx index to search at.

* @param lower lowest valid index.

* @param upper highest valid index.

* @return internal node corresponding to idx.

* @throws IndexOutOfBoundsException if idx is not between lower and upper, inclusive.

*/

private Node getNode( int idx, int lower, int upper )

{

Node p;

if( idx < lower || idx > upper )

throw new IndexOutOfBoundsException( "getNode index: " + idx + "; size: " + size( ) );

if( idx < size( ) / 2 )

{

p = beginMarker.next;

for( int i = 0; i < idx; i++ )

p = p.next;

}

else

{

p = endMarker;

for( int i = size( ); i > idx; i-- )

p = p.prev;

}

return p;

}

/**

* Removes an item from this collection.

* @param idx the index of the object.

* @return the item was removed from the collection.

*/

public AnyType remove( int idx )

{

return remove( getNode( idx ) );

}

/**

* Removes the object contained in Node p.

* @param p the Node containing the object.

* @return the item was removed from the collection.

*/

private AnyType remove( Node p )

{

p.next.prev = p.prev;

p.prev.next = p.next;

theSize--;

modCount++;

return p.data;

}

/**

* Returns a String representation of this collection.

*/

public String toString( )

{

StringBuilder sb = new StringBuilder( "[ " );

for( AnyType x : this )

sb.append( x + " " );

sb.append( "]" );

return new String( sb );

}

/**

* Obtains an Iterator object used to traverse the collection.

* @return an iterator positioned prior to the first element.

*/

public java.util.Iterator iterator( )

{

return new LinkedListIterator( );

}

/**

* This is the implementation of the LinkedListIterator.

* It maintains a notion of a current position and of

* course the implicit reference to the MyLinkedList.

*/

private class LinkedListIterator implements java.util.Iterator

{

private Node current = beginMarker.next;

private int expectedModCount = modCount;

private boolean okToRemove = false;

public boolean hasNext( )

{

return current != endMarker;

}

public AnyType next( )

{

if( modCount != expectedModCount )

throw new java.util.ConcurrentModificationException( );

if( !hasNext( ) )

throw new java.util.NoSuchElementException( );

AnyType nextItem = current.data;

current = current.next;

okToRemove = true;

return nextItem;

}

public void remove( )

{

if( modCount != expectedModCount )

throw new java.util.ConcurrentModificationException( );

if( !okToRemove )

throw new IllegalStateException( );

MyLinkedList.this.remove( current.prev );

expectedModCount++;

okToRemove = false;

}

}

/**

* This is the doubly-linked list node.

*/

private class Node

{

public Node( AnyType d, Node p, Node n )

{

data = d; prev = p; next = n;

}

public AnyType data;

public Node prev;

public Node next;

}

private int theSize;

private int modCount = 0;

private Node beginMarker;

private Node endMarker;

}

?

Hire Me For All Your Tutoring Needs
Integrity-first tutoring: clear explanations, guidance, and feedback.
Drop an Email at
drjack9650@gmail.com
Chat Now And Get Quote