C++实现归并排序

归并排序的基本思想:

分治法 :归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组。
递归 :通过递归的方式,不断地将数组一分为二,直到每个子数组只有一个元素(此时视为有序)。
合并:将两个有序子数组合并成一个有序数组。

cpp 复制代码
void merge(vector<int>& arr, vector<int>& tempArr, int left, int mid, int right) {
	//标记左半部分第一个未排序的元素
	int l_pos = left;
	//标记右半部分第一个未排序的元素
	int r_pos = mid + 1;
	//临时数组元素的下标,也就是排序后数组的起始位置
	int pos = left;

	//合并
	while (l_pos <= mid && r_pos <= right) {
		if (arr[l_pos] < arr[r_pos])
			tempArr[pos++] = arr[l_pos++];
		else
			tempArr[pos++] = arr[r_pos++];
	}

	//合并左半区剩余的元素
	while (l_pos <= mid)
		tempArr[pos++] = arr[l_pos++];

	//合并右半区剩余的元素
	while (r_pos <= right)
		tempArr[pos++] = arr[r_pos++];
	
	//把临时数组合并后的元素赋值回原来的数组
	while (left <= right) {
		arr[left] = tempArr[left];
		++left;
	}
	
}

void mergeSort(vector<int>& arr, vector<int>& tempArr, int left, int right) {
	//如果只有一个元素就不需要划分
	if (left < right) {
		int mid = (left + right) / 2;
		//递归划分左半区
		mergeSort(arr, tempArr, left, mid);
		//递归划分右半区
		mergeSort(arr, tempArr, mid + 1, right);
		//合并已经排好序的部分
		merge(arr, tempArr, left, mid, right);
	}
}

int main() {
	vector<int> nums{ 30, 24, 5, 58, 18, 36, 12, 42, 39 };
	cout << "排序前:";
	for (int num : nums)
		cout << num << " ";
	cout << endl;
	vector<int> tempArr(nums.size());
	mergeSort(nums, tempArr, 0, nums.size() - 1);
	cout << "归并排序后:";
	for (int num : nums)
		cout << num << " ";
	cout << endl;
}
相关推荐
明洞日记7 分钟前
【VTK手册036】网格拓扑简化工具:vtkCleanPolyData 使用指南
c++·图像处理·ai·vtk·图形渲染
wakaka_Yu10 分钟前
COLMAP 3.13.0 + CUDA 12.9 + Ubuntu24.04 编译
c++
范纹杉想快点毕业12 分钟前
欧几里得算法与扩展欧几里得算法,C语言编程实现(零基础全解析)
运维·c语言·单片机·嵌入式硬件·算法
f***241113 分钟前
Bug悬案:技术侦探的破案指南
算法·bug
Swift社区15 分钟前
LeetCode 472 连接词
算法·leetcode·职场和发展
Dream it possible!17 分钟前
LeetCode 面试经典 150_二分查找_搜索旋转排序数组(114_33_C++_中等)
c++·leetcode·面试
CoovallyAIHub22 分钟前
YOLO-Maste开源:首个MoE加速加速实时检测,推理提速17.8%!
深度学习·算法·计算机视觉
清铎26 分钟前
leetcode_day13_普通数组_《绝境求生》
数据结构·算法
_OP_CHEN28 分钟前
【从零开始的Qt开发指南】(二十)Qt 多线程深度实战指南:从基础 API 到线程安全,带你实现高效并发应用
开发语言·c++·qt·安全·线程·前端开发·线程安全
hetao173383736 分钟前
2026-01-09~12 hetao1733837 的刷题笔记
c++·笔记·算法