算法合集之《动态规划算法时间效率的优化》

算法合集之《动态规划算法时间效率的优化》

ID:37408940

大小:185.50 KB

页数:13页

时间:2019-05-12

算法合集之《动态规划算法时间效率的优化》_第1页
算法合集之《动态规划算法时间效率的优化》_第2页
算法合集之《动态规划算法时间效率的优化》_第3页
算法合集之《动态规划算法时间效率的优化》_第4页
算法合集之《动态规划算法时间效率的优化》_第5页
资源描述:

《算法合集之《动态规划算法时间效率的优化》》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

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

2、划从中选择一些歌曲来发行m张唱片,每张唱片至多包含t分钟的音乐,唱片中的歌曲不能重叠。按下面的标准进行选择:(1)这组唱片中的歌曲必须按照它们创作的顺序排序;(2)包含歌曲的总数尽可能多。输入n,m,t,和n首歌曲的长度,它们按照创作顺序排序,没有一首歌超出一张唱片的长度,而且不可能将所有歌曲的放在唱片中。输出所能包含的最多的歌曲数目。设n首歌曲按照创作顺序排序后的长度为long[1..n],则动态规划的状态表示描述为:g[i,j,k],(0≤i≤n,0≤j≤m,0≤k

3、≥long[i],i≥1时:g[i,j,k]=max{g[i-1,j,k-long[i]]+1,g[i-1,j,k]}当k

4、,j]=min{g[i-1,j],g[i-1,j-1]+long[i]}其中(a,b)+long[i]=(a’,b’)的计算方法为:当b+long[i]≤t时:a’=a;b’=b+long[i];当b+long[i]>t时:a’=a+1;b’=long[i];规划的边界条件:当0≤i≤n时,g[i,0]=(0,0)题目所求的最大值是:answer=max{k

5、g[n,k]≤(m-1,t)}算法的时间复杂度为:O(n2)。Back例三、石子合并问题(NOI`95)[问题描述]在一个操场上摆放着一圈n堆石子。现要将石子有次序地合并成一堆。规定每次只能选相邻的2堆石子合

6、并成新的一堆,并将新的一堆的石子数记为该次合并的得分。试编程求出将n堆石子合并成一堆的最小得分和最大得分以及相应的合并方案。本例只考虑最大得分。i

7、:设合并第i堆到第j堆石子的最优断开位置s[i,j]=p,且i

8、合并第i堆到第j堆石子的最优断开位置s[i,j]=p矛盾情况2、t[i,p]>t[p+1,j]与情况1是对称的。状态转移方程优化为:m[i,j]=max{m[i+1,j],m[i,j-1]}+t[i,j]i

9、:任意个辅

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。