- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
05动态规划讲解
* * 第五讲 动态规划 (Dynamic programming) * * 一、经典问题:数塔(1788) 有形如下图所示的数塔,从顶部出发,在每一结点可以选择向左走或是向右走,一直走到底层,要求找出一条路径,使路径上的值最大。 * * 用暴力的方法,可以吗? * * 这道题如果用枚举法(暴力思想),在数塔层数稍大的情况下(如31),则需要列举出的路径条数将是一个非常庞大的数目(2^30= 1024^3 10^9=10亿)。 试想一下: * * 拒绝暴力,倡导和谐~ * * 从顶点出发时到底向左走还是向右走应取决于是从左走能取到最大值还是从右走能取到最大值,只要左右两道路径上的最大值求出来了才能作出决策。 同样,下一层的走向又要取决于再下一层上的最大值是否已经求出才能决策。这样一层一层推下去,直到倒数第二层时就非常明了。 如数字2,只要选择它下面较大值的结点19前进就可以了。所以实际求解时,可从底层开始,层层递进,最后得到最大值。 结论:自顶向下的分析,自底向上的计算。 考虑一下: * * 思考:免费馅饼(1789) * * 如何解决? 请发表见解 ? * * 打地鼠1791 再思考: * * 二、经典问题:最长有序子序列 I 0 1 2 3 4 5 6 7 8 Num[I] 1 4 7 2 5 8 3 6 9 * * 解决方案: I 0 1 2 3 4 5 6 7 8 Num[I] 1 4 7 2 5 8 3 6 9 F[I] 1 2 3 2 3 4 3 4 5 * * 思考 FatMouses Speed hdu1160 Sample Input 6008 1300 6000 2100 500 2000 1000 4000 1100 3000 6000 2000 8000 1400 6000 1200 2000 1900 Sample Output4 4 5 9 7 * * 再思考(1792) Super Jumping! Jumping! Juping! 解题思路? * * 三、经典问题:最长公共子序列 1793: Sample Inputabcfbc abfcabprogramming contest abcd mnp Sample Output 4 2 0 * * a b c f b c a 1 1 1 1 1 1 b 1 2 2 2 2 2 f 1 2 2 3 3 3 c 1 2 3 3 3 4 a 1 2 3 3 3 4 b 1 2 3 3 4 4 辅助空间变化示意图 * * f(i,j)= { 由于f(i,j)只和f(i-1,j-1), f(i-1,j)和f(i,j-1)有关, 而在计算f(i,j)时, 只要选择一个合适的顺序, 就可以保证这三项都已经计算出来了, 这样就可以计算出f(i,j). 这样一直推到f(len(a),len(b))就得到所要求的解了. f(i-1,j-1)+1 (a[i]==b[j]) max(f(i-1,j),f(i,j-1)) (a[i]!=b[j]) 子结构特征: * * 四、经典问题:1421 搬寝室 Sample Input 2 1 1 3 Sample Output 4 * * 第一感觉: 根据题目的要求,每次提的两个物品重量差越小越好,是不是每次提的物品一定是重量相邻的物品呢? 证明:假设四个从小到大的数:a、b、c、d,只需证明以下表达式成立即可: (a-b)^2+(c-d)^2 (a-c)^2+(b-d)^2 (a-b)^2+(c-d)^2 (a-d)^2+(b-c)^2 ……(略) * * 预备工作: 排序! * * 第二感觉: 对于一次操作,显然提的物品重量越接近越好,是不是可以贪心呢? 请思考… 考虑以下情况: 1 4 5 8 什么结论? * * 详细分析: 从最简单的情况考虑: 2个物品选一对,结论显然 结论? 4个物品选一对?(如何利用前面的知识) 3个物品选一对,… n个物品选一对,… 最终问题:n个物品选k对,如何?(n=2k) n个物品选二对,… * * 详细分析: p[i][j]表示前 i 个物品中搬 j 对的最少疲劳度. 当i==2*j时 p[i][j]=p[i-2][j-1]+(a[i]-a[i-1])^2 当i2*j时 p[i][j]=min(p[i-1][j] ,p[i-2][j-1]+(a[i]-a[i-1])^2) * * 五、经典问题:1058 Humble Numbers Problem Description A number whose
文档评论(0)