上半部分请参见 《排序算法一览(上):交换类、选择类和插入类排序》。
归并类排序
归并排序(Merge Sort)
归并排序是一种分治法,它反复将两个已经排序的序列合并成一个序列(平均时间复杂度 O(nlogn),最好时间复杂度 O(n)):
- 申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列;
- 设定两个指针,最初位置分别为两个已经排序序列的起始位置;
- 比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置;
- 重复步骤直到某一指针达到序列尾;
- 将另一序列剩下的所有元素直接复制到合并序列尾。
public class Sort { public s
[……]阅读全文