add() メソッドと remove() メソッドを調整して、単一のリンク リストを二重循環リストにしようとしています。
これが私のコードです:
private LLNode<E> head; // the first node in the list
private LLNode<E> tail; // the last node in the list
// Adds the specified new item to the back of the list.
public void add(E newData)
{
if (head == null) // if the list is empty...
addToHead(newData);
else
addAfter(newData, nodeAt(size - 1));
}
// Removes and returns the item at the specified index of the list.
public E remove(int index)
{
if (index == 0) // if removing from the head...
return removeFromHead();
else
return removeAfter(nodeAt(index - 1));
}
private void addToHead(E newItem)
{
LLNode<E> newNode = new LLNode<E>();
newNode.data = newItem;
newNode.next = head;
head = newNode;
head.prev = tail;
tail.next = newNode;
size++;
}
// Removes the head node from the list.
private E removeFromHead()
{
if (head != null) {
E temp = head.data;
head = head.next;
head.prev = tail;
tail.next = head;
size--;
return temp;
} else
throw new NoSuchElementException();
}
// Adds a new node containing the specified data, after the
// specified node in the list.
private void addAfter(E newItem, LLNode<E> where)
{
if (where != null) {
LLNode<E> newNode = new LLNode<E>();
newNode.data = newItem;
newNode.next = where.next;
where.next = newNode;
newNode.prev = where;
size++;
} else {
throw new NoSuchElementException();
}
}
// Removes the node after the specified node in the list.
private E removeAfter(LLNode<E> where)
{
if (where != null && where.next != null) {
E temp = where.next.data;
where.next = where.next.next;
where.next.prev = where;
size--;
return temp;
} else
throw new NoSuchElementException();
}
私の主な方法では:
TopSpinLinkedList<Integer> ll = new TopSpinLinkedList<Integer>(numTokens, spinSize);
//fills LinkedList with tokens
for(int i = 1; i <= numTokens; i++) {
ll.add(i);
}
このメソッドを呼び出そうとすると:
//shifts all elements in LinkedList to left by one
public void shiftLeft()
{
if(head == null || head.next == null)
return;
LLNode<E> temp = new LLNode<E>();
temp = head;
head = head.next;
temp.next = null;
tail.next = temp;
tail = temp;
}
実行時に NullPointerException が発生します。私のadd()およびremove()メソッドと関係があると確信しています。二重循環リンクリストにするために何が間違っているのか正確にはわかりません。どんな助けでも大歓迎です。