欢迎访问宙启技术站
智能推送

如何使用Java中的Merge函数对两个有序数组进行合并?

发布时间:2023-06-29 05:43:00

在Java中,可以使用merge函数对两个有序数组进行合并。下面是一个示例代码:

public class MergeSort {
    public static void main(String[] args) {
        int[] arr1 = {1, 3, 5, 7};
        int[] arr2 = {2, 4, 6, 8};

        int[] mergedArr = merge(arr1, arr2);
        for (int num : mergedArr) {
            System.out.print(num + " ");
        }
    }

    public static int[] merge(int[] arr1, int[] arr2) {
        int[] mergedArr = new int[arr1.length + arr2.length];
        int i = 0, j = 0, k = 0;

        while (i < arr1.length && j < arr2.length) {
            if (arr1[i] < arr2[j]) {
                mergedArr[k++] = arr1[i++];
            } else {
                mergedArr[k++] = arr2[j++];
            }
        }

        // 将剩余元素拷贝到mergedArr中
        while (i < arr1.length) {
            mergedArr[k++] = arr1[i++];
        }

        while (j < arr2.length) {
            mergedArr[k++] = arr2[j++];
        }

        return mergedArr;
    }
}

在上面的示例代码中,有两个有序数组arr1arr2。我们先创建一个长度为arr1.length + arr2.length的新数组mergedArr来存储合并后的结果。

然后我们分别使用三个索引ijk来遍历arr1arr2mergedArr,初始值都为0。

接下来就是比较arr1[i]arr2[j]的大小,将较小的值存入mergedArr[k]中,并将相应的索引加1。不断重复这个过程直到其中一个数组遍历完。

最后,如果有一个数组还有剩余元素,将其全部拷贝到mergedArr中。

最后,返回mergedArr即可。

执行上述代码,输出结果为:1 2 3 4 5 6 7 8,即合并后的有序数组。