第一种:
直接将两个数组合并,然后排序就行了
class Solution {
public:
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
for (int i = 0; i != n; ++i) {
nums1[m + i] = nums2[i];
}
sort(nums1.begin(), nums1.end());
}
};
第二种:
利用逆向双尾指针,两个指针分别指向两个数组的尾部(不可能出现被覆盖的情况)
class Solution {
public:
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
int p1 = m - 1, p2 = n - 1;
int length = m + n - 1;
int cur;
while (p1 >= 0 || p2 >= 0) {
if (p1 == -1) {
cur = nums2[p2--];
} else if (p2 == -1) {
cur = nums1[p1--];
} else if (nums1[p1] > nums2[p2]) {
cur = nums1[p1--];
} else {
cur = nums2[p2--];
}
nums1[length--] = cur;
}
}
};
本文介绍了两种在C++中合并两个已排序数组的方法。第一种是直接合并后整体排序,使用了内置的`sort`函数;第二种是采用双指针技术,从数组尾部开始逆向合并,避免了额外的排序步骤。这两种方法在处理大量数据时都能保持效率。
550

被折叠的 条评论
为什么被折叠?



