acm动态规划入门刘春英.ppt

上传人:max****ui 文档编号:3384722 上传时间:2019-12-13 格式:PPT 页数:38 大小:710.50KB
返回 下载 相关 举报
acm动态规划入门刘春英.ppt_第1页
第1页 / 共38页
acm动态规划入门刘春英.ppt_第2页
第2页 / 共38页
acm动态规划入门刘春英.ppt_第3页
第3页 / 共38页
点击查看更多>>
资源描述
ACM程序设计,杭州电子科技大学刘春英acm,2019/12/13,2,今天,,你了吗?,AC,2019/12/13,3,每周一星(3):,Lomen,2019/12/13,4,第四讲,动态规划(1)(Dynamicprogramming),2019/12/13,5,先热身一下,2019/12/13,6,(1466)计算直线的交点数,问题描述:平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数。输入:n(n=20)输出:每个测试实例对应一行输出,从小到大列出所有相交方案,其中每个数为可能的交点数。样例输入4样例输出03456,2019/12/13,7,初步分析:,我们知道:n条直线互不平行且无三线共点的最多交点数max=1+2+(n-1)=n(n-1)/2,但本题不这么简单,因为问题问的是:这些直线有多少种不同的交点数?,2019/12/13,8,思考2分钟:如何解决?,2019/12/13,9,然后,假设0+4*0+0=0;2、第四条与其中两条平行,交点数为0+(n-1)*1+0=3;3、第四条与其中一条平行,这两条平行直线和另外两点直线的交点数为(n-2)*2=4,而另外两条直线既可能平行也可能相交,因此可能交点数为:0+(n-2)*2+0=4或者0+(n-2)*2+1=54、第四条直线不与任何一条直线平行,交点数为:0+(n-3)*3+0=3或0+(n-3)*3+2=5或0+(n-3)*3+3=6即n=4时,有0个,3个,4个,5个,6个不同交点数。,重点分析n的情况:,2019/12/13,12,从上述n=4的分析过程中,我们发现:m条直线的交点方案数=(m-r)条平行线与r条直线交叉的交点数+r条直线本身的交点方案=(m-r)*r+r条之间本身的交点方案数(0=r109=10亿)。,试想一下:,2019/12/13,16,拒绝暴力,倡导和谐,2019/12/13,17,从顶点出发时到底向左走还是向右走应取决于是从左走能取到最大值还是从右走能取到最大值,只要左右两道路径上的最大值求出来了才能作出决策。同样,下一层的走向又要取决于再下一层上的最大值是否已经求出才能决策。这样一层一层推下去,直到倒数第二层时就非常明了。如数字2,只要选择它下面较大值的结点19前进就可以了。所以实际求解时,可从底层开始,层层递进,最后得到最大值。结论:自顶向下的分析,自底向上的计算。,考虑一下:,2019/12/13,18,二、思考题:最长有序子序列,2019/12/13,19,解决方案:,2019/12/13,20,三、1160FatMousesSpeed,SampleInput60081300600021005002000100040001100300060002000800014006000120020001900,SampleOutput44597,2019/12/13,21,题目分析:,设Micei.W表示第i只老鼠的重量,Micei.S表示第i只老鼠的速度。我们先对Mice进行排序,以W为第一关键字,从小到大,S为第二关键字,从大到小。设fi为Micei至Micen最长的序列长度。考虑某一个fi,则有:fi=max(fi,fj+1)(1Micej.W,Micei.SMicej.S)其中,初始条件为fi=1(i=1,2,.,n)。,2019/12/13,22,Qestion:,两个问题有本质区别吗?,2019/12/13,23,思考(期末考试题):,SuperJumping!Jumping!Jumping!,解题思路?,2019/12/13,25,四、1159CommonSubsequence,SampleInputabcfbcabfcabprogrammingcontestabcdmnp,SampleOutput420,2019/12/13,26,辅助空间变化示意图,2019/12/13,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),子结构特征:,2019/12/13,28,理论小结,2019/12/13,29,如果各个子问题不是独立的,不同的子问题的个数只是多项式量级,如果我们能够保存已经解决的子问题的答案,而在需要的时候再找出已求得的答案,这样就可以避免大量的重复计算。由此而来的基本思路是,用一个表记录所有已解决的子问题的答案,不管该问题以后是否被用到,只要它被计算过,就将其结果填入表中。,一、动态规划的基本思想,2019/12/13,30,二、动态规划的基本步骤,动态规划算法通常用于求解具有某种最优性质的问题。在这类问题中,可能会有许多可行解。每一个解都对应于一个值,我们希望找到具有最优值(最大值或最小值)的那个解。设计一个动态规划算法,通常可以按以下几个步骤进行:,2019/12/13,31,(1)找出最优解的性质,并刻画其结构特征。(2)递归地定义最优值。(3)以自底向上的方式计算出最优值。(4)根据计算最优值时得到的信息,构造一个最优解。其中(1)(3)步是动态规划算法的基本步骤。在只需要求出最优值的情形,步骤(4)可以省去。若需要求出问题的一个最优解,则必须执行步骤(4)。此时,在步骤(3)中计算最优值时,通常需记录更多的信息,以便在步骤(4)中,根据所记录的信息,快速构造出一个最优解。,基本步骤,2019/12/13,32,三、动态规划问题的特征,动态规划算法的有效性依赖于问题本身所具有的两个重要性质:1、最优子结构:当问题的最优解包含了其子问题的最优解时,称该问题具有最优子结构性质。2、重叠子问题:在用递归算法自顶向下解问题时,每次产生的子问题并不总是新问题,有些子问题被反复计算多次。动态规划算法正是利用了这种子问题的重叠性质,对每一个子问题只解一次,而后将其解保存在一个表格中,在以后尽可能多地利用这些子问题的解。,2019/12/13,33,思考:免费馅饼,2019/12/13,34,如何解决?,请发表见解,Anyquestion?,2019/12/13,36,课后任务:,一、DIY在线作业(4):2008ACMProgrammingExercise(4)_动态规划二、常规练习(包含以上作业)1003、1466、1087、1159、1176、1058、1069、2059、2084、2151,2019/12/13,37,下一讲:,计算几何,2019/12/13,38,WelcometoHDOJ,ThankYou,
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 课件教案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!