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]; } } }
标签:
leetCode算法提升
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix