Java 中合并 K 个排序数组的算法是否正确?

Is this algorithm for Merge K sorted arrays in Java correct?

我在面试中被要求编写一个 Java 程序来合并 K 个排序数组。 输入如下:

int[][] kSortedArrs = { {1, 5, 6, 8},
                {2, 4, 10, 12},
                {3, 7, 9, 11},
                {13, 14, 15, 16}} ;

我知道合并两个排序数组的解决方案,所以我编写了那个方法 (mergeSortedArrs) 并反复使用它作为这个问题的解决方案。 代码如下所示:

    public static int[] mergeKSortedArrays(int[][] arr) {
        int[] mergedArr = new int[] {};
        for(int i=0; i < arr.length; i++) {
            mergedArr = mergeSortedArrs(mergedArr, arr[i]);
        }
        return mergedArr;
    }

    private static int[] mergeSortedArrs(int[] arr1, int[] arr2) {
        int[] arr3 = new int[arr1.length + arr2.length];
        int i = 0;
        int j = 0;
        for (int k = 0; k < arr3.length; k++) {
            if (i >= arr1.length) {
                arr3[k] = arr2[j++];
                continue;
            }
            if (j >= arr2.length) {
                arr3[k] = arr1[i++];
                continue;
            }
            arr3[k] = arr1[i] <= arr2[j] ? arr1[i++] : arr2[j++];
        }
        return arr3;
    }

我的代码运行良好,至少对于给我的测试用例是这样。 但是我想知道这个解决方案在正确性方面是否有任何缺点,因为我在互联网上搜索但找不到与我的这个解决方案接近的解决方案。因此,如果我搞砸了什么,我有点怀疑。 欢迎推荐。

您的代码是正确的并且解决了问题,但是速度很慢。假设您有 k 个列表,每个列表包含 1 个元素,您的代码将合并前两个,然后添加第三个,然后添加第四个,依此类推,总运行时复杂度为 O(k^2)

如果你改为对数组进行单次传递,将第一个与第二个合并,第三个与第四个合并,依此类推,你最终会得到 k/2 个长度为 2,它在 O(k) 中运行。再次执行此操作以获得 k/4 个长度为 4 的列表,依此类推,直到只有一个列表。这在 O(k log k) 中运行,速度要快得多。