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   一颗蛋50斤  阅读(44)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示