复习2-归并排序

归并排序属于分而治之的思想,对数组一分为二,分别对两部分排序,再做合并。有几个关键点:

1. 一分为二后,每部分做递归的归并排充,直到遇到一个元素为止。

2. 合并时一定是将两个排好序的子数组做合并,类似于插入排序。

算法实现如下:

函数主体
合并函数

这里面有两个问题:merge 插入排序时需要 make 一个辅助slice, 并做数据拷贝,对于大数组会 make 很多次,对GC有一定压力。插入排序时一定要处理好子数组边界问题。

20160706再好好想想能不能更高效? 特别是辅助slice,看能不能去掉。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,286评论 0 2
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,224评论 0 52
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,747评论 0 15
  • 一. 写在前面 要学习算法,“排序”是一个回避不了的重要话题,在分析完并查集算法和常用数据结构之后,今天我们终于可...
    Leesper阅读 2,555评论 0 40
  • 我总是不停地站在人生的十字路口 选择,选择…… 选择完一次,又要面临下一次 这一次次的内心 与现实的斗争 多少个失...
    艾任阅读 160评论 0 1