【数据结构排序】归并排序

什么是归并排序

定义:

基本思想:
归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide andConquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。

归并思路

先将一个数组一直分治,递归思想,当left>=begin时候就比较俩数据大小,将比较完的数据再放到数组中再和右树进行比较将两数组的数据比较完后,再放入新的数组当中 不断地递归 归并,这就是归并的思路
图例:
在这里插入图片描述
代码方面为接口型 先开创一个空间因为归并需要辅助空间进行排序,

void MergeSort(int* a, int n)
{
	int left = 0;
	int right = n - 1;
	int* tmp = malloc(sizeof(int)*n);
	_MergeSort(a, left,right, tmp);
}

这里将left和end的值进行保存选取中间值, 分成两个数组进行递归,返回排好序的数组进行重新赋值。

	int begin = left;
	int end = right;
	int mid = (begin + end) / 2;
	if (left > right)
	{
		return;
	}
	_MergeSort(a,left,mid,tmp);
	_MergeSort(a,mid+1,right,tmp);

这里就定义begin1和begin2,end1和end2也就是俩数组的头和尾递归时侯也是一样,代表头尾然后堆begin1和begin2进行比较图中就表示的是10,6.
将小的放入新的数组当中这样就拍好了长度为2的俩数组然后往上返回,再比较合并后的begin1和begin1然后再排序再给新的数组赋值。最终将排好序的tmp数组给a数组进行赋值。

void _MergeSort(int* a, int left,int right,int* tmp)
{
	int begin = left;
	int end = right;
	int mid = (begin + end) / 2;
	if (left > right)
	{
		return;
	}
	_MergeSort(a,left,mid,tmp);
	_MergeSort(a,mid+1,right,tmp);
	
	int begin1 = left, end1 = mid;
	int begin2 = mid + 1, end2 = right;
	int index = begin1;
	while (begin1 <= end1 || begin2 <= end2)
	{
		if (a[begin1] < a[begin2])
		{
			tmp[index++] = a[begin1++];
		}
		else
			tmp[index++] = a[begin2++];
	}
	while(begin1<end1)
	{
		tmp[index++] = a[begin1++]
	}
	while(begin2<end2)
	{
		tmp[index++] = a[begin2++]
	}
	for (int i = left; i < right; i++)
	{
		a[i] = tmp[i];
	}
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值