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;
}
相关推荐
焦耳加热25 分钟前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn33 分钟前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6061 小时前
常用排序算法核心知识点梳理
算法·排序
鹅毛在路上了2 小时前
C++, ffmpeg, libavcodec-RTSP拉流,opencv实时预览
c++·opencv·ffmpeg
John_ToDebug2 小时前
定制 ResourceBundle 的实现与 DuiLib 思想在 Chromium 架构下的应用解析
c++·chrome·ui
蒋星熠3 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油4 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream4 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL4 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法
aramae4 小时前
C++ -- 模板
开发语言·c++·笔记·其他