1. 分治法与动态规划主bai要共同点:
二者都要求原问题du具有最优子结构性zhi质,都是将原问题分而治之,分解成若干个规模较小(小到很容易解决的程序)的子问题.然后将子问题的解合并,形成原问题的解.
2. 分治法与动态规划实现方法:
① 分治法通常利用递归求解.
② 动态规划通常利用迭代法自底向上求解,但也能用具有记忆功能的递归法自顶向下求解.
3. 分治法与动态规划主要区别:
① 分治法将分解后的子问题看成相互独立的.
② 动态规划将分解后的子问题理解为相互间有联系,有重叠部分.
例子:
斐波那契数列为例:F(0)=1,F(1)=1, F(n)=F(n-1)+F(n-2)
1.使用递归从上往下的方法为:分治法,它将每个子问题看成独立的,因此会计算很多重复的子子问题。
2.采用递归+备忘录 和 从下往上的递推方法:动态规划
转载:https://zhidao.baidu.com/question/1945805938926194788.html