动态规划入门讲解.pptVIP

  1. 1、本文档共31页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 动态规划入门讲解 by 张惜今 引入 我们用一个简单的例子来让大家了解什么是动态规划 博丽灵梦是东方幻想乡中博丽神社的巫女,她跟幻想乡中最老资格的妖怪八云紫一起维护着隔绝幻想乡与现实世界的大结界,维护现实世界不被幻想乡中的妖怪侵害,幻想乡中的生物也可以自由自在的维持古老的生活方式。 但不幸的是,每隔六十年,结界会有一次大异变,为了维护结界的完整,博丽灵梦必须将灵力注入灵符,让灵力以最好的方式游走来修复结界。 灵梦的灵符是一个三角形,由一堆数字组成,每个数字表示灵力经过这个位置获得的修复值,三角形共n层,第i层有i个数字,从上方的最尖端注入灵力,灵力只能前往前位置的左下方或者右下方,最终走的下面的边的某个位置释放,问灵梦最多可以获得多少修复值? 灵梦的灵符(USACO 1.5.1) 最容易想到的方法: 我们可以列举每一条可能的路线,分别累加比较每条路线的修复值进行比较,取得最大的一条作为答案。我们先不引入时间复杂度的计算,来用一个n较小的例子手工计算我们需要做的计算量。 为什么会计算那么多次呢? 因为这个算法有天然呆的属性,多次经过同一个点,太健忘了! 到这个点为止的最大和其实已经算出来了, 而回溯法在每次回溯时会重复计算! 这样要计算多少次? 我们先不引入时间复杂度的计算,来用一个n较小的例子手工计算我们需要做的计算量。 n==4,共有2^(4-1)=8条路线 每条两次加法和一次比较,共24次计算。 但是如果n=100呢?n=1000呢?指数级的运算量将会飞快增长 换一种方法 取当前和较大的一种路线记录下来,往下走的时候直接用这个数跟下面点的修复值相加。 每一层都看做一个这样的问题,也就是到当前位置可以获得的最大值,依次类推。 原问题答案:到最下面某个位置(也就是最后一层子问题的[当前位置])的最大修复值。 这就是传说中的: 这样的计算次数 进行1次比较和1次加法 (1+4)*4/2-1=9个点 共计算18次。 虽然只少了6次,但n增长时与n^2成正比的计算量就可以接受了。 动态规划的定义 动态规划是: 运筹学的一个分支 解决策过程最优化的数学方法 把多阶段过程转化为一系列单阶段问题 动态规划—— 求解可以划分阶段的最优化问题的方法 效率高 局限性 必须可以划分阶段并满足几个条件 指数级-多项式级 动态规划的适用条件 不是一个纯理论的知识 看出来这个题题是考用动态规划求解 感性的认识 1.最优子结构 当前取得了最优值,那么直接用这个值来参与计算后面的状态能使后面的也最优 只要比较取一个值最优的保存 2.无后效性 当前作出决策只会影响后面的状态 前面的决策的影响都在状态中被包含了顺序 3.重叠子问题 也就是有前所述的那种重复计算的减少,动态规划才能减少算法的运行时间 动态规划的要素 阶段 状态 决策 阶段 每个状态属于一个阶段有了前后关系保证最优子结构和无后效性比较明显,是前提也是一种特征 比如:时间的前后,灵梦的灵符那种层次关系 状态 动态规划时操作的对象 表示我们解到了哪一个子问题 1维或者多维 所属的阶段,一些相关信息 决策 是前面阶段的状态向后面的状态转移的操作 是决策把各个阶段的状态依次求出 动态规划的求解模式和程序实现 划分阶段 设计状态 确定决策写出转移 写出方程和边界 递推:看作递推方程,用循环依次递推出每一个状态 记忆化搜索:按搜索的方式写,但是对于已经搜索过的状态直接返回最优值,不再次搜索 按照方程的形态大致分类的几个例题 线性选择 背包问题 区间DP TreeDP 空的裂解原子核(POJ1887) 灵乌路空有着特别姿态的鸦。左足是“分解之足”、右足是“融合之足”、还有制御两者的右手“第三足”,她以这三足操控著究极的能源。 空居住在地灵殿在无聊的时候经常控制原子核进行核裂解来练习自己的能力。她捕捉到了N个原子核,控制每个原子核进行裂解会获得Ci的能量值,她可以依次挑选一个序列进行裂变(不必连续)。但是由于她能力的特殊性,她用来裂解的原子核的能量只能越来越低,否则会导致控制失败而造成核反应制御不能的后果。但是空是一个低智力的笨蛋,她想让你帮忙计算她最多可以控制几个原子核进行裂变。 分析 经典的LIS模型,也就是线性选择型的DP 阶段:按顺序处理到哪一个原子核 状态:f[i]表示处理到第

您可能关注的文档

文档评论(0)

wuyoujun92 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档