排序算法:归并排序(非递归)

文章目录


先赞后看,养成习惯!!!^ _ ^<3 ❤️ ❤️ ❤️
码字不易,大家的支持就是我坚持下去的动力。点赞后不要忘了关注我哦!
所属专栏:排序算法

一、非递归思路

步骤如下:
1.先两两归并,两个为一组
2.然后根据每组的距离gap,分配组数进行排序
3.gap每次扩大2的倍数
4.注意一些细节:首先注意可能会出现最后一组归并会发生数组的越界,因此我们所使用的方法是排完一组拷贝一组,出现越界的情况还要分情况讨论进行判断

如果begin2越界了,那这两组就不需要进行归并了
如果end2越界了,begin2没有越界,那么我们可以把end2修正成n-1,这样就可以两两归并了

细节图解:

二、代码演示

c 复制代码
void _MergeSort(int* a, int n,int* tmp)
{
	int gap = 1;
	while (gap < n)
	{
		for (int i = 0; i < n; i+=2*gap)
		{
			int begin1 = i, end1 = i + gap - 1;
			int begin2 = i + gap, end2 = i + 2 * gap - 1;
			//大于的部分就直接跳出不拷贝了
			if (begin2 >= n)
			{
				break;
			}

			// 如果第二组的右边界越界,修正一下
			if (end2 >= n)
			{
				end2 = n - 1;
			}
			int dex = i;

			while (begin1 <= end1 && begin2 <= end2)
			{
				if (a[begin1] > a[begin2])
					tmp[dex++] = a[begin2++];
				else
					tmp[dex++] = a[begin1++];
			}
			while (begin1 <= end1)
			{
				tmp[dex++] = a[begin1++];
			}

			while (begin2 <= end2)
			{
				tmp[dex++] = a[begin2++];
			}
			//排完一组拷贝一组
			memcpy(a + i, tmp + i, sizeof(int) * (end2 - i + 1));
		}
		gap *= 2;
	}
}


void MergeTest(int* a, int n)
{
	int* tmp = (int*)malloc(sizeof(int) * n);
	if (tmp == NULL)
	{
		perror("malloc fail");
		return;
	}
	//MergeSort(a, 0,n-1,tmp);
	_MergeSort(a,n,tmp);
}


int main()
{
	int a[11] = {3,5,2,1,6,7,9,8,10,11,4};
	MergeTest(a,sizeof(a)/sizeof(int));
	for (int i = 0; i < 11; i++)
		printf("%d ", a[i]);
	return 0;
}


相关推荐
q_354888515312 分钟前
机器学习:Python地铁人流量数据分析与预测系统 基于python地铁数据分析系统+可视化 时间序列预测算法 ✅
大数据·人工智能·python·算法·机器学习·信息可视化·数据分析
永远都不秃头的程序员(互关)43 分钟前
【K-Means深度探索(十二)】K-Means项目实战:从数据到决策的完整工作流!
算法·机器学习·kmeans
散峰而望1 小时前
【基础算法】高精度运算深度解析与优化
数据结构·c++·算法·链表·贪心算法·推荐算法
一起养小猫1 小时前
LeetCode100天Day16-跳跃游戏II与H指数
算法·游戏
mit6.8241 小时前
两个有序集合|状态分析
算法
平生不喜凡桃李1 小时前
LeetCode 两数之和/三数之和
算法·leetcode·两数之和·三数之和
C雨后彩虹1 小时前
中文分词模拟器
java·数据结构·算法·华为·面试
BLi4ee1 小时前
【Scholarly Notes】Adaptive Model Pruning for Federated Learning
算法·机器学习·剪枝
Remember_9931 小时前
【LeetCode精选算法】二分查找专题二
java·数据结构·算法·leetcode·哈希算法
We་ct2 小时前
LeetCode 42. 接雨水:双指针解法深度剖析与全方法汇总
前端·算法·leetcode·typescript