分治策略是对大型问题的一种有效的方法,将一些大规模问题转换为一些小规模问题,分而治之,之前我们讲过了插入排序,插入排序是一种增量方法,当程序规模扩大时效率将下降,这时候我们可以采取分治的方法,本系列讲以归并排序为引子,来详细为大家讲解一下分治法。
(一)递归算法结构解决分治问题
分治法的思想是将几个规模大的问题转化为一些小规模的子问题,合理利用递归可以求解这些子问题。最后合并这些子问题。
(二)分治模式在递归时对的三个步骤
分解
解决
合并
归并排序
分解
解决
合并
具体问题我们可以利用归并排序的问题来讲解一下
还是利用扑克牌的思想,我们面前现在有两堆排好序的扑克牌,面朝上,最小的在上,现在把两堆牌合并,并排好序,牌面向下的放在桌子上。基本步骤就是从两堆牌选出最小的牌,然后按顺序排列,面朝下的放在桌面上重新组成一副牌。下面我们用代码实现。
我们需要建立两个函数,归并函数,归并排序函数。
首先,我们先结果归并的函数:
void merge(int *a,int p,int q,int r)
{
int *tmp = new int[r - p + 1];
int i = p;
int j = q +1;