Pascal动态规划.pptVIP

  • 47
  • 0
  • 约4.25千字
  • 约 22页
  • 2017-08-14 发布于安徽
  • 举报
动态规划---入门篇 Dynamic programming 多阶段决策过程 多阶段决策过程( multistep decision process )是指这样一类特殊的活动过程,过程可以按时间顺序分解成若干个相互联系的阶段,在每一个阶段都需要做出决策,全部过程的决策是一个决策序列。 动态规划(dynamic programming )算法是解决多阶段决策过程最优化问题的一种常用方法,难度比较大,技巧性也很强。利用动态规划算法,可以优雅而高效地解决很多贪婪算法或分治算法不能解决的问题。 求解问题的两个重要性质 最优子结构性质:如果问题的最优解所包含的子问题的解也是最优的,我们就称该问题具有最优子结构性质( 即满足最优化原理 )。最优子结构性质为动态规划算法解决问题提供了重要线索。 子问题重叠性质:在用递归算法自顶向下对问题进行求解时,每次产生的子问题并不总是新问题,有些子问题会被重复计算多次。动态规划算法正是利用了这种子问题的重叠性质,对每一个子问题只计算一次,然后将其计算结果保存在一个表格中,当再次需要计算已经计算过的子问题时,只是在表格中简单地查看一下结果,从而获得较高的解题效率。 动态规划与分治、递归、贪心的区别 递归算法在程序实现上直观容易,但因为子问题被重复计算,且程序背后存在对栈的操作,速度(计算复杂度一般是指数级的)上劣于动态规划。在递归的过程中,通过保存子问题的

文档评论(0)

1亿VIP精品文档

相关文档