leetCode - 88 合并两个有序数组

leetCode - 88 合并两个有序数组

题目

给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。

请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。
注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n 。


来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/merge-sorted-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

从题目中可以看出,给出我们两个有序的数组且是升序的(nums1,nums2),同时也给出了两个数组元素个数的长度,(m,n)。

题解一:

将 nums2 中的元素放入到 nums1 数组中,然后使用 Arrarys 包中的 sort 方法进行排序

class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        for (int i = 0; i < n; i++) {
            nums1[m+i] = nums2[i];
        }
        Arrays.sort(nums1);
    }
}

似乎这样做有些不妥,这样做起来还是慢了些,将 nums2 数组中的元素放入 nums1 数组中,然后再进行一次排序,这样的速度似乎慢了些,我们或许可以一个个将里面的元素取出,然后比较之后放入。

题解二

先定义一个 m+n 长的临时数组存放元素,这样就可以避免到时候取值的时候,值还没有用到就被覆盖了,发生错误。

我们从题目中可以知道,两个数组是按照升序排序的,所以我们依次取出数组中的元素,使用双指针,每次都从两个数组中取出值来比较。将小的元素追加到临时列表中,最后将 nums1 中的元素替换成临时数组中的元素即可

class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int k = m+n;
        int[] temp = new int[k];
        for (int index = 0, nums1Index = 0, nums2Index = 0; index < k; index++) {
            if (nums1Index >= m) {
                temp[index] = nums2[nums2Index++];
            } else if (nums2Index >= n) {
                temp[index] = nums1[nums1Index++];
            } else if (nums1[nums1Index] < nums2[nums2Index]) {
                temp[index] =  nums1[nums1Index++];
            } else {
                temp[index] = nums2[nums2Index++];
            }
        }
        for (int i = 0; i < k; i++) {
            nums1[i] = temp[i];
        }
    }
}

posted on 2022-09-01 22:39  一颗蛋50斤  阅读(57)  评论(0)    收藏  举报

导航