两个无序的数组合并为一个有序的数组

这道题很有意思。

考察对于排序思想的理解。

我相信大部分的人都写过两个有序链表的合并, 不过前提是有序。
这里是无序的。 其次是链表合并指向变化, 不许要开辟额外的空间就可以去做。
这里不可以。 因此是数组。 你可以思考一下充满了挑战性。

那么这道题该如何处理呢?

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;
}

测试结果:
在这里插入图片描述

  • 7
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值