题意
给你两个有序整数数组 nums1 和 nums2,请你将 nums2 合并到 nums1 中,使 nums1 成为一个有序数组。
初始化 nums1 和 nums2 的元素数量分别为 m 和 n 。你可以假设 nums1 的空间大小等于 m + n,这样它就有足够的空间保存来自 nu
ms2 的元素。
示例 1:
输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输出:[1,2,2,3,5,6]
示例 2:
输入:nums1 = [1], m = 1, nums2 = [], n = 0
输出:[1]
提示:
nums1.length == m + n
nums2.length == n
0 <= m, n <= 200
1 <= m + n <= 200
-109 <= nums1[i], nums2[i] <= 109
解题思路
方法一:
将nums2中的数存放好nums1中的剩余位置,接着调用arrays.sort方法
方法二:
1.建立双指针,分别指向nums1与nums2的尾部,比较指针指向两者值的大小
2.从nums1尾部开始遍历,也建立一个指针指向num1的尾部,向nums1的头部遍历.步骤1值较大的放入步骤2指针指的位置
3.循环遍历步骤1,2
4(细节处理).如果nums2中的值没有全部存放进去,另行处理
代码演示
方法一:
class Solution {
public void merge(int[] nums1, int m, int[] nums2, int n) {
for(int i=m;i<m+n;i++)
{
nums1[i]=nums2[i-m];
}
Arrays.sort(nums1);
}
}
运行效果:
info
解答成功:
执行耗时:1 ms,击败了24.48% 的Java用户
内存消耗:38.7 MB,击败了15.86% 的Java用户
方法二
class Solution {
public void merge(int[] nums1, int m, int[] nums2, int n) {
int flag=m+n-1;
while (flag>=0&&m>=1&&n>=1)
nums1[flag--] = nums1[m-1] > nums2[n-1] ? nums1[m-- -1] :nums2[n-- -1];
while (n>=1)
{
nums1[flag--]=nums2[--n];
}
}
}
运行效果
info
解答成功:
执行耗时:0 ms,击败了100.00% 的Java用户
内存消耗:38.4 MB,击败了80.24% 的Java用户