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];
}
}
}
标签:index,int,元素,nums1,88,数组,leetCode,nums2
From: https://www.cnblogs.com/wushuaiqi/p/16648105.html