归并排序是多次将两个或两个以上的有序表合并成一个新的有序表。最简单的归并是直接将两个有序的子表合并成一个有序的表。
2-路归并排序
在内部排序中,通常采用的是2-路归并排序。即:将含有n个元素的序列看成是n个有序的子序列,每个子序列的长度为1,而后两两合并,得到n/2个长度为2或1的有序子序列,再进行两两合并。。。直到最后由两个有序的子序列合并成为一个长度为n的有序序列。2-路归并的核心操作是将一维数组中前后相邻的两个有序序列归并为一个有序序列。
一、排序算法思路:
1、两个有序表归并为一个有序表Merge();
设两个有序表存放在同一数组中相邻位置a[start,mid],a[mid+1,end]。合并过程中,设置i,j指针,其初值分别指向这两个记录区的起始位置。合并时依次比较a[i]和a[j]的关键字,取关键字较小的记录复制到b[k]中,然后将被复制记录的指针i或j加1,以及指向复制位置的指针k加1。
重复这一过程直至两个输入的子文件有一个已全部复制完毕(不妨称其为空),此时将另一非空的子文件中剩余记录依次复制到b中即可。最后复制回a数组中。