I'm trying to merge two (pre-sorted) doubly linked lists together and it keeps getting infinite loops or a one element list when trying to add.
The expected outcome of the code below should be the list:
[0,1,2,3,4,5,6,7,8,9]
So I Have :
public static void main(String[] args) {
TheLinkedList<Integer> oddList = new TheLinkedList<Integer>();
TheLinkedList<Integer> evenList = new TheLinkedList<Integer>();
// Test lists
oddList.add(new Integer(9));
oddList.add(new Integer(7));
oddList.add(new Integer(5));
oddList.add(new Integer(3));
oddList.add(new Integer(2));
oddList.add(new Integer(1));
evenList.add(new Integer(8));
evenList.add(new Integer(6));
evenList.add(new Integer(4));
evenList.add(new Integer(2));
evenList.add(new Integer(0));
//System.out.println(oddList.toString());
//System.out.println(evenList.toString());
oddList.merge(evenList);
//System.out.println(theList.toString());
}
Note this is in a different Class and you CANNOT accesss oddList or evenList directly
// Self explanatory getter and setter methods
public void add(T newValue) {
head = new Node<T>(newValue, head, null);
if (head.getNext() != null)
head.getNext().setPrevious(head);
else
tail = head;
count++;
}
public void merge(TheLinkedList<T> two) {
do {
if (head.getValue().compareTo(two.head.getValue()) <= 0) {
head = head.getNext();
continue;
}
if (head.getValue().compareTo(two.head.getValue()) >= 0){
two.head = two.head.getNext();
}
} while (head != null && two.head != null);
}