java - 合并排序在复制步骤中抛出 ArrayOutOfBounds 错误?

标签 java sorting recursion merge mergesort

我正在尝试实现一个通用的合并排序算法,该算法使用临时数组来存储合并的部分,然后复制排序的数据。但是,程序在复制步骤(最后一个 while 循环)中不断失败,并抛出 ArrayIndexOutOfBounds 异常。我很困惑为什么会发生这种情况!

我知道在这个程序中使用 Array.copy 更简单,但我正在尝试使用循环进行练习。

public static <E extends Comparable<E>> void mergeSort2(E[] array) {
    mergeSortHelper2(array, 0, array.length - 1);
}

private static <E extends Comparable<E>> void mergeSortHelper2(E[] array, int firstIndex, int lastIndex) {
    if (firstIndex >= lastIndex) {
        return;
    }
    //otherwise divide
    int middle = (firstIndex + lastIndex) / 2;

    //conquer with recursion
    mergeSortHelper2(array, firstIndex, middle);
    mergeSortHelper2(array, middle + 1, lastIndex);

    //combine: take in the original array, and all indices
    merge2(array, firstIndex, middle, middle + 1, lastIndex);
}

private static <E extends Comparable<E>> void merge2(E[] array, int leftFirst, int leftLast, int rightFirst, int rightLast) {
    E[] temp = (E[]) Array.newInstance(array.getClass().getComponentType(), (rightLast - leftFirst + 1));
    int indexLeft = leftFirst;
    int indexRight = rightFirst;
    int index = 0;

    while (indexLeft <= leftLast && indexRight <= rightLast) {
        if (array[indexLeft].compareTo(array[indexRight]) < 0) {
            temp[index++] = array[indexLeft++];
        }
        else {
            temp[index++] = array[indexRight++];
        }
    }

    while (indexLeft <= leftLast) {
        temp[index++] = array[indexLeft++];
    }
    while (indexRight <= rightLast) {
        temp[index++] = array[indexRight++];
    }

    int newIndex = 0;

    while (newIndex != temp.length - 1) {
        array[newIndex++] = temp[newIndex++];
    }
}

最佳答案

array[newIndex++] = temp[newIndex++];

您在该行上将 newIndex 递增两次。将其分成两行代码,一行用于递增,然后一行将其用作数组索引。

注意:此模式适用于代码中的其他位置,因为您要递增两个不同索引。例如。

temp[index++] = array[indexLeft++];

由于到达数组末尾时同一变量的双倍增量,它在最终循环中超出了范围。

关于java - 合并排序在复制步骤中抛出 ArrayOutOfBounds 错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53783823/

相关文章:

java - 如何编写一个函数来检查给定的二叉搜索树是否包含给定的值?

MYSQL CTE 递归更新

java - ModelAndView 返回 null SpringBootTest

java - RXJava 获取在错误处理程序中导致异常的对象

java - Hibernate 找不到映射文件 : org. hibernate.UnknownEntityTypeException:无法找到持久器

arrays - PostgreSQL:使用某种排序条件对元素数组进行排序

algorithm - 查找以随意方式存储的连续增加的子序列

java - 部署的 Tomcat 6 webapp 无法连接到 Amazon RDS Oracle 实例

javascript - 一步减少和排序对象数组

python - 如何在python的递归函数中存储和处理变量?