给你两个有序整数数组 nums1 和 nums2,请你将 nums2 合并到 nums1 中,使 nums1 成为一个有序数组。
初始化 nums1 和 nums2 的元素数量分别为 m 和 n 。你可以假设 nums1 的空间大小等于 m + n,这样它就有足够的空间保存来自 nums2 的元素。
示例 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
class Solution { public void merge(int[] nums1, int m, int[] nums2, int n) { int[] nums1copy=new int[m]; //创建一个新的数组,并将nums1拷贝进其中,把nums1当成容器使用 System.arraycopy(nums1,0,nums1copy,0,m); //三个指针变量 int p1,p2,p; p=p1=p2=0; while(p1<m&&p2<n){ //小的先进入数组num1中 if(nums1copy[p1]<=nums2[p2]){ nums1[p]=nums1copy[p1]; p1++; } else{ nums1[p]=nums2[p2]; p2++; } p++; } //继续剩下部分的拷贝 if(p1==m){ for(int i=p2;i<n;i++){ nums1[p]=nums2[i]; p++; } } else{ for(int i=p1;i<m;i++){ nums1[p]=nums1copy[i]; p++; } } } }
原文:https://www.cnblogs.com/congajiayou/p/14593694.html