动态规划

Posted jing-yu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了动态规划相关的知识,希望对你有一定的参考价值。

转自:

动态规划的基本思想

动态规划的基本思想在于发现和定义问题中的子问题,这里子问题可也以叫做状态;以及一个子问题到下一个子问题之间 是如何转化的 也就是状态转移方程

因此我们遇到一个问题的时候 应该想一想这个问题是否能用某种方式表示成一个小问题,并且小问题具有最优子结构

最优子结构:问题的最优解由相关子问题的最优解组合而成,这些子问题可以独立求解

关于最优子结构 我们来看2个示例

1、求无权有向图中q-t的最短路径

如果q-t间的最短路径经过了点w  那么我们可以证明 q-w  w-t也均是最短路径  

所以无权有向图最短路径是具有最优子结构的

2、求无权有向图中q-t的最长的路径

技术分享图片

而无权有向图最长路径中 

q-t的最长路径是是q-r-t 但 q-r缺不是q-r的最长路径  q-s-t-r是一条更长的路径

所以无权有向图最长路径不具有最优子结构

 

动态规划与贪心等其他算法的比较

动态规划与分治,减治

分治       :将大问题分成若干个小问题去解决 递归的求解每个小问题,每个小问题之间没有关系  例如 快排

减治       :将大问题缩减成小问题,减掉的部分不需要考虑,例如:二分查找

动态规划:将原问题分成多个子问题,不同子问题间存在一定的联系,相互间有重叠的子问题

这里我个人认为动态规划分治 减治都是将大问题拆分成小问题 进行求解 区别在于

减治法减掉的部分 可以不用再求解了;

分治法每个小问题都需要进行求解;

动态规划不同的子问题间是有相互重叠的子问题的

 

动态规划与贪心

动态规划在于我们求解了所有子问题  虽然有些子问题最终并不能组成答案

而贪心算法任务无需求解所有子问题,所以选择在当前情况下最优的情况自顶向下的求解问题,贪心可以认为是动态规划的一个特例

如果用一个树来表示子问题的话 可以认为动态规划考虑了树中的所有节点

而贪心算法减去了树了许多枝干,在考虑了通向最优解的那一条路

以上是关于动态规划的主要内容,如果未能解决你的问题,请参考以下文章

算法动态规划 ② ( 动态规划四要素 | 动态规划状态 State | 动态规划初始化 Initialize | 动态规划方程 Function | 动态规划答案 Answer )

算法动态规划 ② ( 动态规划四要素 | 动态规划状态 State | 动态规划初始化 Initialize | 动态规划方程 Function | 动态规划答案 Answer )

算法动态规划 ① ( 动态规划简介 | 自底向上的动态规划示例 | 自顶向下的动态规划示例 )

算法动态规划 ① ( 动态规划简介 | 自底向上的动态规划示例 | 自顶向下的动态规划示例 )

算法动态规划 ③ ( LeetCode 62.不同路径 | 问题分析 | 自顶向下的动态规划 | 自底向上的动态规划 )

算法动态规划 ③ ( LeetCode 62.不同路径 | 问题分析 | 自顶向下的动态规划 | 自底向上的动态规划 )