c++实现归并排序

原创 2016年05月31日 17:35:08

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

归并排序的基本思想:

将待排序序列R[0...n-1]看成是n个长度为1的有序序列,将相邻的有序表成对归并,得到n/2个长度为2的有序表;将这些有序序列再次归并,得到n/4个长度为4的有序序列;如此反复进行下去,最后得到一个长度为n的有序序列。

综上可知:

归并排序其实要做两件事:

(1)“分解”——将序列每次折半划分

(2)“合并”——将划分后的序列段两两合并后排序


我们先来考虑第二步,如何合并

1.在每次合并过程中,都是对两个有序的序列段进行合并,然后排序。

2.这两个有序序列段分别为 R[low, mid] 和 R[mid+1, high]。

3.先将他们合并到一个局部的暂存数组R2中,带合并完成后再将R2复制回R中。

4.为了方便描述,我们称 R[low, mid] 第一段,R[mid+1, high] 为第二段。

5.每次从两个段中取出一个记录进行关键字的比较,将较小者放入R2中。最后将各段中余下的部分直接复制到R2中。

6.经过这样的过程,R2已经是一个有序的序列,再将其复制回R中,一次合并排序就完成了。




//归并排序的最大时间代价,最小时间代价和平均时间代价均为θ(n*logn)。归并排序不依赖于原始数组的有序程度。
//2016.5.29,采用递归方法
#include <iostream>
#include <stdlib.h>
#include <math.h>
#include <time.h>

using namespace std;
#define MAX 10

typedef struct
{
	int data[MAX];
	int length;
}SeqList;


//归并递归排序
void Merge(int a[], int b[], int i, int m,int n)//将a[i...m]和a[m+1...n]归并b[i....n]
{
	int  l, j, k;
	for (k = i, j = m + 1; i < m&&j < n; k++)
	{
		if (a[i] < a[j])     //实现两个数组的合并
			b[k] = a[i++];
		else
			b[k] = a[j++];
	}

	if (i<m)
	for (l = 0; l <m - i; l++)
	{
		b[k+1] = a[l + i];//把i之后的元素补齐到合并的数组b【】中去。
	}
	if (j<n)               //两个if语句只会出现一个。
	for (int l = 0; l < n - j; l++)
	{
		b[k+1] = a[j + l];

	}
}
void MSort(int a[], int b1[], int s, int t)//将a[s...t]归并排序成b1【s...t】.分割后再合并 
{
	int m;
	int b2[MAX + 1];
	if (s == t)
		b1[s] = a[s];//递归终止条件,一般都是分割到只剩下最后一个元素、
	else
	{
		m = (s + t) / 2;//分割成两部分,二路归并
		MSort(a, b2, s, m);//将a[s..m]归并成b2[],这两个部分更像是分割子序列
		MSort(a, b2, m + 1, t);//将a[m+1...t]归并成b2【】
		Merge(b2, b1, s, m, t);//

	}

}


void input(int num[])//实参传入的数组的首地址,而不是整个数组
{
	int i;
	srand((unsigned)time(NULL));//产生随机函数的随机数种子
	for (i = 0; i < MAX; i++)
	{
		num[i] = rand() % 100;
	}
}

void  output(int num[])
{
	int i;
	for (i = 1; i < MAX+1; i++)
	{
		printf("%5d", num[i-1]);
		if (i % 10 == 0)
			printf("\n");
	}

}


void MergeSort(SeqList *seqList)
{
	MSort(seqList->data, seqList->data, 0, seqList->length - 1);
}


/*打印结果*/
void Display(SeqList *seqList)
{
	int i;
	printf("\n**********展示结果**********\n");

	for (i = 0; i<seqList->length; i++)
	{
		printf("%d ", seqList->data[i]);
	}

	printf("\n**********展示完毕**********\n");
}

#define N 9
void main()
{
	int i, j;
	SeqList seqList;

	//定义数组和初始化SeqList
	int d[N] = { 50, 10, 90, 30, 70, 40, 80, 60, 20 };

	for (i = 0; i<N; i++)
	{
		seqList.data[i] = d[i];
	}
	seqList.length = N;

	printf("***************归并排序***************\n");
	printf("排序前:");
	Display(&seqList);

	MergeSort(&seqList);
	printf("\n排序后:");
	Display(&seqList);

	getchar();
}
/*void main()
{
	
	int num[MAX];// num2[MAX];
	cout << "产生的随机无序数组元素为:" << endl;
	input(num);
	output(num);

	cout << "递归归并排序后" << endl;
	MSort(num, num, 0, MAX - 1);
	output(num);
	system("pause");

}*/


版权声明:本文为博主原创文章,未经博主允许不得转载。

算法设计之归并排序(C++实现)

归并排序遵循分治法的思想:将
  • u011426031
  • u011426031
  • 2014年08月23日 07:27
  • 3353

归并排序c++实现

#include using namespace std; /* *归并算法 *将数组a中的下标s~m 和m~e按从小到大的顺序合并 */ void Merge(int *a,int s,int...
  • HE19930303
  • HE19930303
  • 2015年09月14日 19:54
  • 741

C++实现归并排序(使用循环实现)

在上一篇文章中实现了递归方法的归并排序。归并排序时间效率很好,虽然使用递归的方法实现很简单易读,但是容易造成空间性能上的损耗(反复的函数调用引起)。因此,有采用循环的方式实现归排序。给出了两种写法,一...
  • cjbct
  • cjbct
  • 2017年01月10日 15:38
  • 940

归并排序c++代码及详细注释

转自:http://www.cnblogs.com/hxf829/archive/2008/11/18/1659863.html #include using namespace std;...
  • martin_liang
  • martin_liang
  • 2014年12月11日 20:03
  • 3847

用迭代实现归并排序

最近在知乎上看到一个帖子,总结了各种常见的排序算法,并用python一一实现了,不过归并排序的迭代写法,题主说他不会写,我就试了一下,其实很简单。下面会先分析递归的时候实际上做了哪些事,然后迭代如何重...
  • Jacketinsysu
  • Jacketinsysu
  • 2016年09月08日 15:55
  • 1482

归并排序的简单实现(c++ 版本)

归并排序 归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。 将已有序的子序列合并,得到完全有序的序列;即先使每个...
  • chaiwenjun000
  • chaiwenjun000
  • 2015年10月20日 22:59
  • 574

数组及链表的归并排序(C++实现)

本文只是对数组
  • lavorange
  • lavorange
  • 2014年09月04日 13:14
  • 1930

归并排序使用在c++STL实现

相比上一个C++归并排序的版本,这次复习了一下STL的基本方法 因为要使用随机访问迭代器,所以序列使用了vector容器,而要使用lis容器t的merge算法,因此在合并时使用了list容器和vec...
  • shaungyezhai
  • shaungyezhai
  • 2016年07月07日 21:36
  • 1292

算法代码实现之归并排序,C/C++实现,自顶向下与自底向上两种方式

封装成函数merge_sort_up_to_down(自顶向下方式)和merge_sort_down_to_up(自底向上方式): #include //归并操作 void merge(int ...
  • QQ245671051
  • QQ245671051
  • 2016年02月28日 22:05
  • 905

数据结构——归并排序算法

昨天说了快速排序,今天来讲一讲归并排序:什么是归并?归并:将两个或两个以上的有序表组合成一个新有序表。归并操作的步骤: 申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列 设定两个指...
  • u013271921
  • u013271921
  • 2015年05月26日 14:33
  • 7155
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:c++实现归并排序
举报原因:
原因补充:

(最多只允许输入30个字)