前面一篇博客提到的快速排序是排序算法中的一种经典算法。和快速排序一样,合并排序是另外一种经常使用的排序算法。那么合并排序算法有什么不同呢?关键之处就体现在这个合并上面。
    合并算法的基本步骤如下所示:
    1)把0~length-1的数组分成左数组和右数组
    2)对左数组和右数组进行迭代排序
    3)将左数组和右数组进行合并,那么生成的整个数组就是有序的数据数组

下面就开始实践操作:
    a)创建函数,判断参数的合法性

void merge_sort(int array[], int length)
{
if(NULL == array || 0 == length)
return ;
_merge_sort(array, 0, length-1);
}

 b)进行merge函数迭代操作

void _merge_sort(int array[], int start, int end)
{
if(start >= end)
return; int middle = start + ((end - start) >> 1);
_merge_sort(array, start, middle);
_merge_sort(array, middle + 1, end);
_merge_data_in_array(array, start, middle, end);
}

c)对合并后的队列进行合并操作

void _merge_data_in_array(int array[], int start, int middle, int end)
{
int length = end - start + 1;
int* pData = NULL;
int left = start;
int right = middle + 1;
int all = 0; /* allocate new memory to the space */
pData = (int*) malloc(sizeof(int) * length);
assert(NULL != pData);
memset(pData, 0, length); /* begin to move data */
while(right <= end){
while(array[left] <= array[right] && left <= middle){
pData[all] = array[left]; left ++; all ++;
} if(left > middle) {
break;
} while(array[left] > array[right] && right <= end){
pData[all] = array[right]; right ++; all ++;
}
} /* move the left data */
if(left <= middle)
memmove(&pData[all], &array[left], sizeof(int) * (middle -left +1)); if(right <= end)
memmove(&pData[all], &array[right], sizeof(int) * (end - right + 1)); memmove(&array[start], pData, sizeof(int) * length);
free(pData);
}

注: 文中使用的pData动态内存不是一种最优的处理办法,实际开发中可以由其他形式的数据类型代替。

d)编写测试用例

static void test1()
{
int array[] = {1};
merge_sort(array, sizeof(array)/sizeof(int));
} static void test2()
{
int array[] = {2, 1};
merge_sort(array, sizeof(array)/sizeof(int));
assert(1 == array[0]);
assert(2 == array[1]);
} static void test3()
{
int array[] = {3, 2, 1};
merge_sort(array, sizeof(array)/sizeof(int));
assert(1 == array[0]);
assert(2 == array[1]);
assert(3 == array[2]);
} static void test4()
{
int array[] = {4, 3, 5, 1};
merge_sort(array, sizeof(array)/sizeof(int));
assert(1 == array[0]);
assert(3 == array[1]);
assert(4 == array[2]);
assert(5 == array[3]);
}

分析快速排序和合并排序的相同点和不同点:
    相同点: 都是迭代操作
    不同点: 快速排序,先分类再迭代;合并排序,先迭代再合并

c++(合并排序)的更多相关文章

  1. 用javascript比较快速排序和合并排序的优劣

    <script> //用来调用排列方法的类 function arr_sort(arr){ var startTime,endTime; var priv_arr = new Array; ...

  2. julia文件合并排序.jl

    julia文件合并排序.jl """ julia文件合并排序.jl http://bbs.bathome.net/thread-39841-1-1.html 2016年3 ...

  3. lintcode:合并排序数组 II

    题目: 合并排序数组 II 合并两个排序的整数数组A和B变成一个新的数组. 样例 给出A = [1, 2, 3, empty, empty] B = [4,5] 合并之后A将变成[1,2,3,4,5] ...

  4. lintcode:合并排序数组

    题目: 合并排序数组 合并两个排序的整数数组A和B变成一个新的数组. 样例 给出A=[1,2,3,4],B=[2,4,5,6],返回 [1,2,2,3,4,4,5,6] 挑战 你能否优化你的算法,如果 ...

  5. 算法之合并排序(mergeSort)

    合并排序算法在结构上是递归的,采用分治策略:就是将原有的问题划分为 n 个规模较小但结构与原问题相似的子问题,递归地解决这些子问题,然后合并其结果,就得到原问题的解. 合并排序的模式一般如下: 1.分 ...

  6. 算法笔记_014:合并排序(Java)

    1 问题描述 给定一组数据,使用合并排序得到这组数据的非降序排列. 2 解决方案 2.1 合并排序原理简介 引用自百度百科: 合并排序是建立在归并操作上的一种有效的排序算法.该算法是采用分治法(Div ...

  7. 深入浅出数据结构C语言版(21)——合并排序

    在讲解合并排序之前,我们先来想一想这样一个问题如何解决: 有两个数组A和B,它们都已各自按照从小到大的顺序排好了数据,现在我们要把它们合并为一个数组C,且要求C也是按从小到大的顺序排好,请问该怎么做? ...

  8. Java与算法之(11) - 合并排序

    天下事,合久必分,分久必合.合并排序的基本思想正是先分再合. 例如对3, 1这个数列排序,首先是分,分为3和1两个数列,然后再合并并排序.合并需要额外的辅助空间,即建立一个两个数列长度之和的空数组用于 ...

  9. 合并排序 java

    java  实现合并排序 package How; import java.io.BufferedReader; import java.io.BufferedWriter; import java. ...

随机推荐

  1. Java I/O---类体系总结

    1.Java I/O常用 (1)File 对文件系统中文件以及文件夹进行封装的对象,可以通过对象的思想来操作文件和文件夹. (2)FileInputStream 从文件系统中的某个文件中获得输入字节: ...

  2. python链接mysql

    1.安装MySQLdb MySQLdb 是用于Python链接Mysql数据库的接口,它实现了 Python 数据库 API 规范 V2.0,基于 MySQL C API 上建立的. 下载地址: ht ...

  3. express学习

    一.入门 实际开发中一般使用express应用生成器(express-generator),直接生成项目目录,npm安装后再安装需要的依赖: 项目目录:app.js定义并导出整个应用: /bin/ww ...

  4. vue基础入门

    Hello World   <body> <!-- 在angularJS中用ng-model --> <!-- {{mseeage?message:11}}支持三元表达式 ...

  5. Python中range()和len()

  6. 万能选项卡,tab选项卡

    //万能选项卡 function PaPtabs(thisObj, num) { if (thisObj.className == "active") return; var ta ...

  7. volatile关键字的特性总结

    当一个变量定义为volatile后,它将具备两个特性: 1.保证此变量对所有线程的可见性,所谓"可见性",,是指当一个线程修改了这个变量的值,新值对于其他线程来说是可以立即得知的. ...

  8. mac上使用appium连接真机问题

    1.链接真机时一直报错 app is not install 日志如下: 解决办法:是因为lockdown挂了,在命令行输入sudo chmod -R 777 /var/db/lockdown/ 但是 ...

  9. angular4.0配置本机IP访问项目

    一.查看本机IP 命令行输入 ipconfig,在面板中选择IPv4地址 二.在项目中配置IP 打开package.json文件,修改如下 三.命令行运行 npm start 四.在手机上访问 192 ...

  10. dubbo源码—service reference

    service reference 在编写好服务之后,dubbo会将服务export出去,这个时候就可以编写consumer来调用这个服务了.dubbo作为一个rpc框架,使用者使用远程服务和使用本地 ...