这道题很有意思。
考察对于排序思想的理解。
我相信大部分的人都写过两个有序链表的合并, 不过前提是有序。
这里是无序的。 其次是链表合并指向变化, 不许要开辟额外的空间就可以去做。
这里不可以。 因此是数组。 你可以思考一下充满了挑战性。
那么这道题该如何处理呢?
1、将一个数组元素插入到另一个数组中,然后调用一次排序算法。
这种思想可以说, 非常简单, 还有点取巧。
我们分析性能, 时间复杂度, 我们采用快速排序去做。nlogn, 感觉还可以哦!
我想这种思想是可以说的,但是不能作为最终的解法。 可以提一提。
2、那么核心来了。
每个数组采用快速排序成有序,然后归并排序。
归并排序的思想分为两部分: 先拆分,后合并
1> 将数组拆分各个小数组。 当数组的元素拆分到1个元素时,则停止
2> 两两合并有序的小数组,最终合并称为有序数组。
我摆一张归并思想图:
很显然, 这道题就是要用归并排序, 归并排序就像是量身制作的。
而且很简单,只需要实现归并的合并部分就行。
是不是很简单呢!!
这道题考察的是算法思想的理解, 每种算法的适应场合。
下面是我写的代码:
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int main() {
int arr1[5] = { 5,4,3,2,1 };
int arr2[] { 10,9,8,7,6 };
//两次快速排序
sort(arr1, arr1 + sizeof(arr1) / sizeof(arr1[0]));
sort(arr2, arr2 + sizeof(arr2) / sizeof(arr2[0]));
int str1len = sizeof(arr1) / sizeof(arr1[0]), str2len = sizeof(arr2) / sizeof(arr2[0]);
int begin1 = 0, begin2 = 0;
int end1 = str1len - 1, end2 = str2len - 1;
int total_index = 0;
//额外数组
vector<int> vec(str1len + str2len);
while (begin1 <= end1 && begin2 <= end2) {
if (arr1[begin1] < arr2[begin2]) { vec[total_index++] = arr1[begin1++]; }
else { vec[total_index++] = arr2[begin2++]; }
}
while (begin1 <= end1) { vec[total_index++] = arr1[begin1++]; }
while (begin2 <= end2) { vec[total_index++] = arr2[begin2++]; }
for (const auto& vit : vec) {
cout << vit << ' ';
}
cout << endl;
return 0;
}
测试结果: