java - 如何在我的合并排序实现中发现错误?

标签 java algorithm sorting merge mergesort

我尝试编写一个归并排序算法,但我看不出哪里出错了。你能告诉我我做错了什么吗?或者建议一些有用的资源/算法实践?

public class MergeSort {

private int[] auxArray;

public void sort(int[] array)
{
    auxArray = new int[array.length];
    sort(array, 0, array.length - 1);

        for (int i = 0; i < array.length; i++) {
            System.out.println(array[i]);
      }

}

private void sort(int[] array, int begin, int end)
{
    if( begin >= end) return ;

    int middle = begin + (end - begin) / 2;

    sort(array, begin, middle);
    sort(array, middle + 1, end);
    merge(array, begin, middle, end);

}


private void merge(int[] array, int begin, int middle, int end)
{

    int i = begin;
    int j = middle + 1;

    for (int k = begin; k <= end; k++) {
        auxArray[k] = array[k];
    }

    for (int k = begin; k <= end; k++)
    {
        if(i > middle) array[k] = auxArray[j++];
        else if(j > end) array[k] = auxArray[i++];
        else if(array[i] >= array[j])
        {
            array[k] = auxArray[j++];
        }
        else
            array[k] = auxArray[i++];
    }

}

public static void main(String[] args) throws Exception {

    MergeSort sort = new MergeSort();

    int[] array = new int[] {10, 9, 8, 7, 6, 5 ,4, 3, 2 ,1};

    sort.sort(array);

}
}

最佳答案

在merge()中,改变

        else if(array[i] >= array[j])

        else if(auxArray[i] >= auxArray[j])

关于java - 如何在我的合并排序实现中发现错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38809507/

相关文章:

java - JPA/hibernate : code based validation of jpa queries

java - 使用 long 而不是 int 时程序更快

java - 为整数数组创建自定义排序?

java - Camel收件人列表不迭代所有收件人

java - Struts ajax 404错误

algorithm - 曼哈顿距离如何成为一种可接受的启发式算法?

c++ - 从重载函数 std::real<float> 解析地址

Python:如何将自定义类成员与内置类型进行比较

python - 使用递归对仅包含 0 和 1 的列表进行排序

java - 如何确定Gradle中的源目录优先级?