算法的设计有很多思想,之前的插入排序使用的是增量的方法,即在排好的子数组A中,将元素A[j]插入,形成新的子数组A。
这次将实现另一种排序——归并排序,归并排序采用了“分治法”(divide-and-conquer),本篇中包含
- 分治法的一些定义
- 归并排序的实现
- 归并排序的算法分析
- 参考资料
一、什么是分治法?
分治法,也可以称为分治策略:是将一个大规模的问题(原问题)划分成n个规模较小而结构与原问题相似的子问题,递归地解决这些子问题,然后再合并其结果,就得到原问题的解。
分治模式在每一层递归上都有三个步骤:
分解(divide):将原问题分解成一系列子问题
解决(conquer):递归地解决各子问题。若子问题足够小,则直接求解
合并(combine):将子问题的结果合并成原问题的解
合并排序(merge sort)即参照了上述的模式:
分解:将n个元素分成各含n/2个元素的子序列
解决:用合并排序法对两个子序列递归地排序
合并:合并两个已排