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;
}
相关推荐
aini_lovee1 分钟前
基于粒子群算法(PSO)优化BP神经网络权值与阈值的实现
神经网络·算法
专注于ai算法的踩坑小达人4 分钟前
C++变量全面总结
c++·qt
老鼠只爱大米10 分钟前
LeetCode经典算法面试题 #230:二叉搜索树中第K小的元素(递归法、迭代法、Morris等多种实现方案详细解析)
算法·leetcode·二叉搜索树·二叉树遍历·第k小的元素·morris遍历
星期五不见面12 分钟前
嵌入式学习!(一)C++学习-leetcode(21)-26/1/29
学习·算法·leetcode
阿猿收手吧!13 分钟前
【C++】atmoic原子操作与并发安全全解析
开发语言·c++·安全
2501_9413220318 分钟前
通信设备零部件识别与检测基于改进YOLOv8-HAFB-2算法实现
算法·yolo
凯子坚持 c22 分钟前
C++基于微服务脚手架的视频点播系统---客户端(1)
开发语言·c++·微服务
modelmd25 分钟前
【递归算法】汉诺塔
python·算法
CSDN_RTKLIB27 分钟前
SharedPtr测试步骤说明
c++
呱呱巨基29 分钟前
Linux 第一个系统程序 进度条
linux·c++·笔记·学习