0

我认为smallIndex,indextemp都有值,所以我不确定为什么我会收到错误。谁能向我解释为什么会这样?错误信息是:

线程“主”java.lang.NullPointerException 中的异常

public class LinkedList
{
  public class LinkedListNode
  {
     public int info;
     public LinkedListNode next;
     public LinkedListNode back;

     public LinkedListNode()
     {
        info = 0;
        next = null;
        back = null;
     }
     public LinkedListNode(int item)
     {
        info = item;
        next = null;
        back = null;
     }
     public void displayInfo()
     {
        System.out.print(info + " ");
     }
  }
  protected int count;
  protected LinkedListNode first;
  protected LinkedListNode last;

  public LinkedList()
  {
     first = null;
     last = null;
     count = 0;
  }
  public void initializeList()
  {
     first = null;
     last = null;
     count = 0;
  }
  public boolean isEmpty()
  {
     return (first == null);
  }
  public int length()
  {
     return count;
  }
  public void print()
  {
     LinkedListNode current = first;
     while (current != null)
     {
        current.displayInfo();
        current = current.next;
     }
  }
  public void insertNode(int insertItem)
  {
     LinkedListNode newNode = new LinkedListNode(insertItem);
     if (isEmpty())
     {
        first = newNode;
        last = newNode;
        count++;
     }
     else
     {
        last.next = newNode;
        newNode.back = last;
     }
     last = newNode;
  }
  public LinkedListNode partition(LinkedList list,
  LinkedListNode first, LinkedListNode last)
  {
     LinkedListNode smallIndex = first;
     LinkedListNode index = smallIndex.next;
     LinkedListNode temp = new LinkedListNode();
     int pivot = first.info;

     while (index != last.next)
     {
        if((index.info) < pivot)
        {
           smallIndex = smallIndex.next;
           temp.info = index.info;
           index.info = smallIndex.info;
           smallIndex.info = temp.info;
        }
        index = index.next;
     }
     temp.info = first.info;
     first.info = smallIndex.info;
     smallIndex.info = temp.info;
     System.out.print("The list after QuickSort is: "); 
     list.print();
     System.out.print("\n");
     return smallIndex;
  }
  public void recQuickSort(LinkedList list, LinkedListNode first,
  LinkedListNode last)
  {
     while(first != last)
     {
        LinkedListNode pivotLocation = partition(list, first, last);
        recQuickSort(list, first, pivotLocation.back);
        recQuickSort(list, pivotLocation.next, last);
     }
  }
  public void quickSortLinkedList(LinkedList list)
  {
     recQuickSort(list, list.first, list.last);
  }

}



import java.util.*;

public class testLinkedListQuickSort
{
  static Scanner console = new Scanner(System.in);

  public static void main(String[] args) 
  {
     LinkedList linkedlist = new LinkedList();
     int num;

     System.out.println("Enter numbers to add to linked list:");
     num = console.nextInt();
     while (num != 0)
     {
        linkedlist.insertNode(num);
        num = console.nextInt();
     }
     linkedlist.quickSortLinkedList(linkedlist);
     linkedlist.print();
  }
}
4

3 回答 3

1

关于您的评论:您将分区称为

recQuickSort(list, first, pivotLocation.back);

Do if pivotLocation.backis nullthen the partition方法被调用last == null,导致你的NPE。

于 2012-11-07T05:42:09.407 回答
0

NullPointerException当您尝试访问没有价值的引用时会发生。

或者调用空对象的实例方法,访问或修改空对象的字段时。

或者当您将 null 传递给需要实际值的方法时。意思是说空对象被非法使用。

我没有过多地查看您的代码,但要解决此问题,请确定哪个 Object 实例为空并导致问题。您需要修改代码以添加正确的空检查验证

于 2012-11-07T05:49:35.383 回答
0

在您的partition()方法中,您没有对null值进行太多检查。例如,如果smallIndexindextemplastare null,那么它就会爆炸。还有first,如果是null,会导致 NPE 。

确保在递归调用中传递的不是空节点是个好主意。我没有看到很多支票。

于 2012-11-07T05:38:44.213 回答