合并排序 - 我的代码出了什么问题?

时间:2013-10-23 21:27:20

标签: java mergesort

我的合并排序代码出现问题。每次我运行它时都会遇到IndexOutOfBounds Exception的问题,但我似乎无法弄明白为什么......这是我们的教授(众所周知会犯错误)所产生的代码......有人发现了问题

public static <T extends Comparable<T>> void mergeSort(T[] array, int first, int last)
{
    if(first<last)
    {
        int mid = (first+last)/2;
        mergeSort(array, first, mid);
        mergeSort(array, mid+1, last);
        merge(array, first, mid, last);
    }
}

public static <T extends Comparable<T>> void mergeSort(T[] array, int last)
{
    int first = 0;
    if(first<last)
    {
        int mid = (first+last)/2;
        mergeSort(array, first, mid);
        mergeSort(array, mid+1, last);
        merge(array, first, mid, last);
    }
}
public static <T extends Comparable<T>> void merge(T[] array, int first, int mid, int last)
{
    int maxSize = array.length;
    T[] tempA = (T[]) new Comparable[maxSize];

    int first1 = first;
    int last1 = mid;
    int first2 = mid+1;
    int last2 = last;

    int index = first1;
    while((first1<=last1) && (first2<=last2))
    {
        if(array[first1].compareTo(array[first2])<0)
        {
            tempA[index] = array[first1];
            first1++;
        }
        else
        {
            tempA[index] = array[first2];
            first2++;
        }
        index++;
    }
    while(first1<=last1)
    {
        tempA[index]=array[first1];
        first1++;
        index++;
    }
    while(first2<=last2)
    {
        tempA[index]=array[first2];
        first2++;
        index++;
    }
    for(index=first; index<=last;++index)
    {
        array[index]=tempA[index];
    }
}

1 个答案:

答案 0 :(得分:1)

阅读代码时,似乎last变量用作代码中的索引。

这就是为什么你不能将它作为mergeSort方法的大小传递给你,你必须通过array.length - 1

  • array.length是数组的大小
  • array.length - 1是数组的最后一个索引