Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 asone sorted array.
* Note:
The number of elements initialized in nums1 and nums2 are m and nrespectively.
You may assume that nums1 has enough space (size that is greater or equal to m + n) to hold additional elements from nums2.
* Example:
* Input:
nums1 = [1,2,3,0,0,0], m = 3
nums2 = [2,5,6], n = 3
* Output: [1,2,2,3,5,6]
下面这段代码超时。思想:两个数列比,从头开始比较,将小的数换到nums1,剩下的nums2直接补全nums1即可。
(注意考虑到:nums1:400000 nums2:12356这种情况)
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
int i=0,j=0;
while(j < n){
if(nums1[i] > nums2[j] && nums1[i] < nums2[j+1]){
int temp;
temp = nums1[i];
nums1[i] = nums2[j];
nums2[j] = temp;
j++;
}
if(i < m)
i++;
}
for(j=0;j<n;j++){
nums1[m] = nums2[j];
m++;
}
}
思想:到着来,两个数组中最大的元素放在最后。 ✔ Accepted ✔ 59/59 cases passed (4 ms) ✔ Your runtime beats 100 % of cpp submissions ✔ Your memory usage beats 100 % of cpp submissions (8.7 MB)
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
int i = m+n-1;
while(n > 0){
if(m>0 && nums1[m-1]>=nums2[n-1]){
nums1[i] = nums1[m-1];
m--;
}
else{
nums1[i] = nums2[n-1];
n--;
}
i--;
}
}