1.基本概念:
分治策略是对于一个规模为n的问题,若该问题可以容易地解决(比如说规模n较小)则直接解决,否则将其分解为k个规模较小的子问题,这些子问题互相独立且与原问题形式相同,递归地解这些子问题,然后将各子问题的解合并得到原问题的解。
2.问题特征:
(1)该问题规模缩小到一定的程度就容易解决;
(2)该问题可分解为若干个规模较小的相同问题,即该问题具有最优子结构性质。
(3)利用该问题分解出的子问题的解可合并为该问题的解;
(4)该问题所分解出的各个子问题是相互独立的,即子问题之间不包含公共的子问题。
第二条特征是应用分治法的前提,此特征反映了递归思想的应用;能否利用分治法关键完全取决于问题是否具有第三条特征;如果具备了第一条和第二条特征,而不具备第三条特征,则可以考虑用贪心法或动态规划法。第四条特征涉及到分治法的效率,如果各子问题是不独立的,则分治法要做许多不必要的工作,重复地解公共的子问题,此时虽然可用分治法,但一般用动态规划法较好。
3.分治法基本步骤:
分治法在每一层递归上都有三个步骤:分解–》解决-》合并
Eg: (1)将P分解为较小的子问题 P1 ,P2 ,…,Pk
(2) 递归解决Pi
(3) 合并子问题
注:
递归算法基本思想:找出递归子结构(数学表达式)性质(原问题的解包含了子问题的解)、用子问题的解来递归定义原问题的解、找出递归终止条件(迭代,注意边界和次数)。
分治法基本思想:问题分解(分解成k个规模大致相同的子问题)、子问题递归求解、合并各个子问题的解。
4.改进分治算法的途径:
(1)通过代数变换减少子问题的个数
(2)利用预处理减少递归内部的计算量(eg:快速排序中加入随机化算法)