ImageVerifierCode 换一换
格式:PPT , 页数:13 ,大小:103KB ,
资源ID:8086554      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-8086554.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(动态规划算法时间效率的优化.ppt)为本站会员(kpmy5893)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

动态规划算法时间效率的优化.ppt

1、动态规划算法时间效率的优化,福州第三中学 毛子青,动态规划算法的时间复杂度=状态总数*每个状态转移的状态数*每次状态转移的时间,一、减少状态总数二、减少每个状态转移的状态数三、减少状态转移的时间,1、改进状态表示;(例一),1、减少决策时间 (例三),方法:采用恰当的数据结构;,2、减少计算递推式的时间,方法:进行预处理,利用计算结果等;,2、其他方法:选取恰当的规划方向等;,1、根据最优解的性质减少决策量;(例二),2、其他方法:利用四边形不等式证明决策的单调性等;,例一、 Raucous Rockers 演唱组(USACO96) 问题描述现有n首由Raucous Rockers 演唱组录制

2、的歌曲,计划从中选择一些歌曲来发行m张唱片,每张唱片至多包含t分钟的音乐,唱片中的歌曲不能重叠。按下面的标准进行选择:(1) 这组唱片中的歌曲必须按照它们创作的顺序排序;(2) 包含歌曲的总数尽可能多。输入n,m,t,和n首歌曲的长度,它们按照创作顺序排序,没有一首歌超出一张唱片的长度,而且不可能将所有歌曲的放在唱片中。输出所能包含的最多的歌曲数目。,设n首歌曲按照创作顺序排序后的长度为long1n,则动态规划的状态表示描述为:gi, j, k,(0in,0jm,0kt), 表示前i首歌曲,用j张唱片另加k分钟来录制,最多可以录制的歌曲数目。 状态转移方程为: 当klongi,i1时: gi,

3、 j, k=maxgi-1,j,k-longi+1,gi-1,j,k 当klongi,i1时: gi, j, k=maxgi-1,j-1,t-longi+1,gi-1,j,k 规划的边界条件为: 当0jm, 0kt时:g0,j,k=0; 问题的最优解为:gn,m,0。,算法的时间复杂度为:O(n*m*t)。,改进的状态表示描述为:gi,j=(a, b),0in,0ji,0am,0bt,表示在前i首歌曲中选取j首录制所需的最少唱片为:a张唱片另加b分钟。 状态转移方程为: gi, j=mingi-1,j,gi-1,j-1+longi 其中(a, b)+longi=(a, b)的计算方法为: 当b

4、+longi t时: a=a; b=b+longi; 当b+longi t时: a=a+1; b=longi; 规划的边界条件: 当0in时,gi,0=(0,0) 题目所求的最大值是:answer=maxk| gn, k(m-1,t),算法的时间复杂度为:O(n2)。,Back,例三、石子合并问题(NOI95) 问题描述在一个操场上摆放着一圈n堆石子。现要将石子有次序地合并成一堆。规定每次只能选相邻的2堆石子合并成新的一堆,并将新的一堆的石子数记为该次合并的得分。试编程求出将n堆石子合并成一堆的最小得分和最大得分以及相应的合并方案。 本例只考虑最大得分。,ij,规划的边界条件为:mi,i=0令

5、si,j=k,表示合并的最优断开位置。算法的时间复杂度为O(n3)。,设各堆的石子数依次为d1n,则动态规划的状态表示为:mi,j,1i, jn,表示合并dij所得到的最大得分: 令 ,则状态转移方程为:,合并第i堆到第j堆石子的最优断开位置si,j要么等于i,要么等于j-1,也就是说最优合并方案只可能是: (i) (i+1 j) 或 (i j-1) (j) ,证明:设合并第i堆到第j堆石子的最优断开位置 si,j=p,且itp+1,j 与情况1是对称的。,状态转移方程优化为: mi,j=maxmi+1,j, mi,j-1+ti,j ij 规划的边界条件是: mi,i=0 算法的时间复杂度O(

6、n2)。,Back,例三、LOSTCITY (NOI2000) 问题描述 现给出一张单词表、特定的语法规则和一篇文章: 文章和单词表中只含26个小写英文字母az。 单词表中的单词只有名词,动词和辅词这三种词性,且相同词性的单词互不相同。单词的个数不超过1000,单词的长度均不超过20。 语法规则可简述为:名词短语:任意个辅词前缀接上一个名词;动词短语:任意个辅词前缀接上一个动词;句子:以名词短语开头,名词短语与动词短语相间连接而成。 文章的长度不超过5k。且已知文章是由有限个句子组成的,句子只包含有限个单词。 编程将这篇文章划分成最少的句子,在此前提之下,要求划分出的单词数最少。,我们分别用v

7、,u,a表示动词,名词和辅词,给出的文章用L1M表示,则状态表示描述为: F(v,i):表示将L的前i个字符划分为以动词结尾(当iM时,可带任意个辅词后缀)的最优分解方案下划分的句子数与单词数; F(u,i):表示将L的前i个字符划分为以名词结尾(当iM时,可带任意个辅词后缀)的最优分解方案下划分的句子数与单词数。 状态转移方程为: F(v,i)=min F(u,j)+(0,1), L(j+1i)为动词;F(v,j)+(0,1), L(j+1i)为辅词,iM; F(u,i)=min F(u,j)+(1,1), L(j+1i)为名词;F(v,j)+(0,1), L(j+1i)为名词;F(u,j)+(0,1), L(j+1i)为辅词,iM; 边界条件:F(v,0)=(1,0); F(u,0)=(, ); 问题的解为:min F(v,M), F(u,M) ;,Back,采用不同的方法查找字符串的比较:设单词表的规模为N(N的最大值为1000)设文章的长度为M(M的最大值为 5000),(测试环境:Pentium 200 / 32MB),

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报