电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本
换一换
首页 金锄头文库 > 资源分类 > PPT文档下载
分享到微信 分享到微博 分享到QQ空间

ACM算法 动态规划(1)

  • 资源ID:54148524       资源大小:418.50KB        全文页数:40页
  • 资源格式: PPT        下载积分:10金贝
快捷下载 游客一键下载
账号登录下载
微信登录下载
三方登录下载: 微信开放平台登录   支付宝登录   QQ登录  
二维码
微信扫一扫登录
下载资源需要10金贝
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
支付方式: 支付宝    微信支付   
验证码:   换一换

 
账号:
密码:
验证码:   换一换
  忘记密码?
    
1、金锄头文库是“C2C”交易模式,即卖家上传的文档直接由买家下载,本站只是中间服务平台,本站所有文档下载所得的收益全部归上传人(卖家)所有,作为网络服务商,若您的权利被侵害请及时联系右侧客服;
2、如你看到网页展示的文档有jinchutou.com水印,是因预览和防盗链等技术需要对部份页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有jinchutou.com水印标识,下载后原文更清晰;
3、所有的PPT和DOC文档都被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;下载前须认真查看,确认无误后再购买;
4、文档大部份都是可以预览的,金锄头文库作为内容存储提供商,无法对各卖家所售文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;
5、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据;
6、如果您还有什么不清楚的或需要我们协助,可以点击右侧栏的客服。
下载须知 | 常见问题汇总

ACM算法 动态规划(1)

2018/9/8,1,ACM 程序设计,计算机学院 刘春英,2018/9/8,2,今天,,你 了吗?,AC,2018/9/8,3,每周一星(3):,liuzewei,2018/9/8,4,第四讲,动态规划(1) (Dynamic programming),2018/9/8,5,先热身一下,2018/9/8,6,(1466)计算直线的交点数,问题描述:平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数。 输入:n(n<=20) 输出:每个测试实例对应一行输出,从小到大列出所有相交方案,其中每个数为可能的交点数。 样例输入 4 样例输出 0 3 4 5 6,2018/9/8,7,思考2分钟:如何解决?,2018/9/8,8,初步分析:,我们将n条直线排成一个序列, 直线2和直线1最多只有一个交点, 直线3与直线1和直线2最多有两个交点., 直线n和其他n-1条直线最多有n-1个交点, 由此得出n条直线互不平行且无三线共点的最多交点数max=1+2+(n-1)=n(n-1)/2,但本题不这么简单,因为问题问的是:这些直线有多少种不同的交点数?,2018/9/8,9,容易列举出N=1,2,3的情况: 0 0,1 0,2,3 如果已知 无交点; 2、第四条与其中两条平行,交点数为(n-1)*1+0=3; 3、第四条与其中一条平行,这两条平行直线和另外两点直线的交点数为(n-2)*2=4,而另外两条直线既可能平行也可能相交,因此可能交点数为:(n-2)*2+0=4 或者 (n-2)*2+1=5 4、 第四条直线不与任何一条直线平行,交点数为:(n-3)*3+0=3 或者 (n-3)*3+2=5 或者 (n-3)*3+3=6 即n=4时,有0个,3个,4个,5个,6个不同交点数。,2018/9/8,10,从上述n=4的分析过程中,我们发现:m条直线的交点方案数=(m-r)条平行线与r条直线交叉的交点数+ r条直线本身的交点方案=(m-r)*r+r条之间本身的交点方案数(1<=r<=m),2018/9/8,11,一、数塔问题,有形如下图所示的数塔,从顶部出发,在每一结点可以选择向左走或是向右走,一直走到底层,要求找出一条路径,使路径上的值最大。,2018/9/8,12,用暴力的方法,可以吗?,2018/9/8,13,试想一下:这道题如果用枚举法(暴力思想),在数塔层数稍大的情况下(如31),则需要列举出的路径条数将是一个非常庞大的数目(230= 10243 > 109=10亿)。,2018/9/8,14,所以,不可以如此暴力!,2018/9/8,15,考虑一下:从顶点出发时到底向左走还是向右走应取决于是从左走能取到最大值还是从右走能取到最大值,只要左右两道路径上的最大值求出来了才能作出决策。同样,下一层的走向又要取决于再下一层上的最大值是否已经求出才能决策。这样一层一层推下去,直到倒数第二层时就非常明了。如数字2,只要选择它下面较大值的结点19前进就可以了。所以实际求解时,可从底层开始,层层递进,最后得到最大值。结论:自顶向下的分析,自底向上的计算。,2018/9/8,16,Understand?,2018/9/8,17,二、思考题:最长有序子序列,请回答: 穷举(暴力)方法的时间复杂度是多少?,2018/9/8,18,解决方案:,2018/9/8,19,三、HDOJ_1160 FatMouse's Speed,题目链接 Sample Input 6008 1300 6000 2100 500 2000 1000 4000 1100 3000 6000 2000 8000 1400 6000 1200 2000 1900,Sample Output 4 4 5 9 7,2018/9/8,20,题目分析:,设Micei.W表示第i只老鼠的重量,Micei.S表示第i只老鼠的速度。我们先对Mice进行排序,以W为第一关键字,从小到大,S为第二关键字,从大到小。 设fi为Micei至Micen最长的序列长度。考虑某一个fi,则有: fi = max(fi, fj+1) (1 Micej.W,Micei.S < Micej.S) 其中,初始条件为fi=1 (i=1, 2, ., n)。,2018/9/8,21,Qestion:,两个问题有本质区别吗?,2018/9/8,22,思考(期末考试题):,Super Jumping! Jumping! Jumping!,2018/9/8,23,解题思路?,2018/9/8,24,四、HDOJ_1159 Common Subsequence,题目链接 Sample Input abcfbc abfcab programming contest abcd mnp,Sample Output 4 2 0,2018/9/8,25,请先计算暴力算法的时间复杂度: (当然是指最坏情况!),?,2018/9/8,26,辅助空间变化示意图,2018/9/8,27,子结构特征: 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 (ai=bj),max(f(i-1,j),f(i,j-1) (ai!=bj),2018/9/8,28,理论总结,2018/9/8,29,一、动态规划的基本思想,2018/9/8,30,如果各个子问题不是独立的,不同的子问题的个数只是多项式量级,如果我们能够保存已经解决的子问题的答案,而在需要的时候再找出已求得的答案,这样就可以避免大量的重复计算。由此而来的基本思路是,用一个表记录所有已解决的子问题的答案,不管该问题以后是否被用到,只要它被计算过,就将其结果填入表中。,一、动态规划的基本思想,2018/9/8,31,二、动态规划的基本步骤,动态规划算法通常用于求解具有某种最优性质的问题。在这类问题中,可能会有许多可行解。每一个解都对应于一个值,我们希望找到具有最优值(最大值或最小值)的那个解。设计一个动态规划算法,通常可以按以下几个步骤进行:,2018/9/8,32,(1)找出最优解的性质,并刻画其结构特征。 (2)递归地定义最优值。 (3)以自底向上的方式计算出最优值。 (4)根据计算最优值时得到的信息,构造一个最优解。其中(1)(3)步是动态规划算法的基本步骤。在只需要求出最优值的情形,步骤(4)可以省去。若需要求出问题的一个最优解,则必须执行步骤(4)。此时,在步骤(3)中计算最优值时,通常需记录更多的信息,以便在步骤(4)中,根据所记录的信息,快速构造出一个最优解。,2018/9/8,33,三、动态规划问题的特征,动态规划算法的有效性依赖于问题本身所具有的两个重要性质:1、最优子结构:当问题的最优解包含了其子问题的最优解时,称该问题具有最优子结构性质。2、重叠子问题:在用递归算法自顶向下解问题时,每次产生的子问题并不总是新问题,有些子问题被反复计算多次。动态规划算法正是利用了这种子问题的重叠性质,对每一个子问题只解一次,而后将其解保存在一个表格中,在以后尽可能多地利用这些子问题的解。,2018/9/8,34,思考:免费馅饼,2018/9/8,35,如何解决?,请发表见解 ,2018/9/8,36,Any Question?,2018/9/8,37,附录:DP练习题(HDOJ):,1003、1087、1159、1160、1176 1024、1025、1058、1069、1081 1074、1157、1158、14661078、1080、1114 1203、1294、1227、1223 1500、1501、1502、1503 1505、1506、1510、2059,2018/9/8,38,课后一定要练习! DP”相-当-”重要!,2018/9/8,39,有志于参加竞赛的同学, 加油!,2018/9/8,40,ACM, 天天见!,

注意事项

本文(ACM算法 动态规划(1))为本站会员(飞***)主动上传,金锄头文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即阅读金锄头文库的“版权提示”【网址:https://www.jinchutou.com/h-59.html】,按提示上传提交保证函及证明材料,经审查核实后我们立即给予删除!

温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.