合并两个有序数组


给你两个按非递减顺序排列的整数数组 nums1nums2,另有两个整数 mn ,分别表示 nums1nums2 中的元素数目。

请你合并 nums2nums1 中,使合并后的数组同样按非递减顺序排列。

注:最终合并后数组不应由函数返回,而是存储在数组 nums1 中。

为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n

进阶:你可以设计实现一个时间复杂度为 O(m + n) 的算法解决此问题吗?

1.双指针

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
//while循环写法
class Solution {
public:
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
int k = m + n - 1;
int i = m - 1, j = n - 1;
while (i >= 0 && j >= 0) {
if (nums1[i] >= nums2[j]) {
nums1[k] = nums1[i];
i--;
k--;
} else {
nums1[k] = nums2[j];
j--;
k--;
}
}
while (i >= 0) {
nums1[k] = nums1[i];
i--;
k--;
}
while (j >= 0) {
nums1[k] = nums2[j];
j--;
k--;
}
}
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//for循环写法
class Solution {
public:
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
for (int i = m + n - 1; i >= 0; --i) {
if (n == 0 || m != 0 && nums1[m - 1] >= nums2[n - 1]) {
nums1[i] = nums1[m - 1];
m--;
} else {
nums1[i] = nums2[n - 1];
n--;
}
}
}
};