Build your own Linked List class : List « Collections Data Structure « Java






Build your own Linked List class

       

public class Main {
  public static void main(String[] args) {
    LinkedList theList = new LinkedList();
    LinkedListIterator theItr;

    theItr = theList.zeroth();
    printList(theList);

    for (int i = 0; i < 10; i++) {
      theList.insert(new Integer(i), theItr);
      printList(theList);
      theItr.advance();
    }
    System.out.println("Size was: " + listSize(theList));

   }

  public static int listSize(LinkedList theList) {
    LinkedListIterator itr;
    int size = 0;
    for (itr = theList.first(); itr.isValid(); itr.advance())
      size++;
    return size;
  }

  public static void printList(LinkedList theList) {
    if (theList.isEmpty())
      System.out.print("Empty list");
    else {
      LinkedListIterator itr = theList.first();
      for (; itr.isValid(); itr.advance())
        System.out.print(itr.retrieve() + " ");
    }
    System.out.println();
  }
}

class LinkedList {
  public LinkedList() {
    header = new ListNode(null);
  }

  public boolean isEmpty() {
    return header.next == null;
  }

  public void makeEmpty() {
    header.next = null;
  }

  public LinkedListIterator zeroth() {
    return new LinkedListIterator(header);
  }

  public LinkedListIterator first() {
    return new LinkedListIterator(header.next);
  }

  public void insert(Object x, LinkedListIterator p) {
    if (p != null && p.current != null)
      p.current.next = new ListNode(x, p.current.next);
  }

  public LinkedListIterator find(Object x) {
    ListNode itr = header.next;

    while (itr != null && !itr.element.equals(x))
      itr = itr.next;

    return new LinkedListIterator(itr);
  }

  public LinkedListIterator findPrevious(Object x) {
    ListNode itr = header;

    while (itr.next != null && !itr.next.element.equals(x))
      itr = itr.next;

    return new LinkedListIterator(itr);
  }

  public void remove(Object x) {
    LinkedListIterator p = findPrevious(x);

    if (p.current.next != null)
      p.current.next = p.current.next.next; // Bypass deleted node
  }

  private ListNode header;

}

class LinkedListIterator {
  LinkedListIterator(ListNode theNode) {
    current = theNode;
  }

  public boolean isValid() {
    return current != null;
  }

  public Object retrieve() {
    return isValid() ? current.element : null;
  }

  public void advance() {
    if (isValid())
      current = current.next;
  }

  ListNode current;
}

class ListNode {
  public ListNode(Object theElement) {
    this(theElement, null);
  }

  public ListNode(Object theElement, ListNode n) {
    element = theElement;
    next = n;
  }

  public Object element;

  public ListNode next;
}

   
    
    
    
    
    
    
  








Related examples in the same category

1.Using the Double Brace Initialization.
2.Add to end Performance compare: LinkList and ArrayListAdd to end Performance compare: LinkList and ArrayList
3.Add to start Performance compare: LinkList and ArrayList
4.Convert array to list and sortConvert array to list and sort
5.Shuffle a listShuffle a list
6.Sort a listSort a list
7.Bidirectional Traversal with ListIteratorBidirectional Traversal with ListIterator
8.Int listInt list
9.Linked List example
10.List to array
11.List Reverse Test
12.List Search Test List Search Test
13.Convert a List to a Set
14.Set Operating on Lists: addAll, removeAll, retainAll, subList
15.Convert collection into array
16.Convert LinkedList to array
17.Convert Set into List
18.If a List contains an item
19.ListSet extends List and Set
20.List containing other lists
21.Helper method for creating list
22.Generic to list
23.List implementation with lazy array construction and modification tracking.
24.Utility methods for operating on memory-efficient lists. All lists of size 0 or 1 are assumed to be immutable.
25.A class that wraps an array with a List interface.
26.Splits the list.
27.Slice a list
28.A List that, like a Set, contains no duplicate Elements.
29.Determines if the given lists contain the same elements. We suppose that all the elements of the given lists are different.
30.List that allows items to be added with a priority that will affect the order in which they are later iterated over.