您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 管理学资料 > 其它技巧lecture动态规划
2020/1/171今天,你了吗?2020/1/172每周一星(3):混沌的云Knight2020/1/173第四讲动态规划(1)(Dynamicprogramming)2020/1/174先热身一下——2020/1/175(1466)计算直线的交点数问题描述:平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数。输入:n(n=20)输出:每个测试实例对应一行输出,从小到大列出所有相交方案,其中每个数为可能的交点数。样例输入4样例输出034562020/1/176初步分析:我们知道:n条直线互不平行且无三线共点的最多交点数max=1+2+……(n-1)=n(n-1)/2,但本题不这么简单,因为问题问的是:这些直线有多少种不同的交点数?2020/1/177思考2分钟:如何解决?2020/1/178然后,假设=n-1的情况都已经知道——分析思路——首先,容易列举出N=1,2,3的情况:00,10,2,32020/1/179先来看个统计的方法:假设一共有n=a+b条直线(即n条直线分成2组,分别为a条和b条)则总的交点数=a内的交点数+b内的交点数+a,b之间的交点数重点分析——n的情况:2020/1/1710我们来分析加入第N条直线的情况(这里以N=4为例):(分类方法:和第N条直线平行的在a组,其余在b组)1、第四条与其余直线全部平行=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的情况:2020/1/1711从上述n=4的分析过程中,我们发现:m条直线的交点方案数=(m-r)条平行线与r条直线交叉的交点数+r条直线本身的交点方案=(m-r)*r+r条之间本身的交点方案数(0=rm)重点分析——n的情况:2020/1/1712一、数塔问题有形如下图所示的数塔,从顶部出发,在每一结点可以选择向左走或是向右走,一直走到底层,要求找出一条路径,使路径上的值最大。2020/1/1713用暴力的方法,可以吗?2020/1/1714这道题如果用枚举法(暴力思想),在数塔层数稍大的情况下(如31),则需要列举出的路径条数将是一个非常庞大的数目(2^30=1024^310^9=10亿)。试想一下:2020/1/1715拒绝暴力,倡导和谐~2020/1/1716从顶点出发时到底向左走还是向右走应取决于是从左走能取到最大值还是从右走能取到最大值,只要左右两道路径上的最大值求出来了才能作出决策。同样,下一层的走向又要取决于再下一层上的最大值是否已经求出才能决策。这样一层一层推下去,直到倒数第二层时就非常明了。如数字2,只要选择它下面较大值的结点19前进就可以了。所以实际求解时,可从底层开始,层层递进,最后得到最大值。结论:自顶向下的分析,自底向上的计算。考虑一下:2020/1/1717二、思考题:最长有序子序列I012345678Num[I]1472583692020/1/1718解决方案:I012345678Num[I]147258369F[I]1232343452020/1/1719三、1160FatMouse'sSpeedSampleInput60081300600021005002000100040001100300060002000800014006000120020001900SampleOutput445972020/1/1720题目分析:设Mice[i].W表示第i只老鼠的重量,Mice[i].S表示第i只老鼠的速度。我们先对Mice进行排序,以W为第一关键字,从小到大,S为第二关键字,从大到小。设f[i]为Mice[i]至Mice[n]最长的序列长度。考虑某一个f[i],则有:f[i]=max(f[i],f[j]+1)(1=ji,且Mice[i].WMice[j].W,Mice[i].SMice[j].S)其中,初始条件为f[i]=1(i=1,2,...,n)。2020/1/1721Qestion:两个问题有本质区别吗?2020/1/1722思考(期末考试题):SuperJumping!Jumping!Juping!解题思路?2020/1/1724四、1159CommonSubsequenceSampleInputabcfbcabfcabprogrammingcontestabcdmnpSampleOutput4202020/1/1725abcfbca111111b122222f122333c123334a123334b123344辅助空间变化示意图2020/1/1726f(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])子结构特征:2020/1/1727思考:免费馅饼2020/1/1728如何解决?请发表见解Anyquestion?2020/1/1730理论小结2020/1/1731如果各个子问题不是独立的,不同的子问题的个数只是多项式量级,如果我们能够保存已经解决的子问题的答案,而在需要的时候再找出已求得的答案,这样就可以避免大量的重复计算。由此而来的基本思路是,用一个表记录所有已解决的子问题的答案,不管该问题以后是否被用到,只要它被计算过,就将其结果填入表中。一、动态规划的基本思想2020/1/1732二、动态规划的基本步骤动态规划算法通常用于求解具有某种最优性质的问题。在这类问题中,可能会有许多可行解。每一个解都对应于一个值,我们希望找到具有最优值(最大值或最小值)的那个解。设计一个动态规划算法,通常可以按以下几个步骤进行:2020/1/1733(1)找出最优解的性质,并刻画其结构特征。(2)递归地定义最优值。(3)以自底向上的方式计算出最优值。(4)根据计算最优值时得到的信息,构造一个最优解。其中(1)-(3)步是动态规划算法的基本步骤。在只需要求出最优值的情形,步骤(4)可以省去。若需要求出问题的一个最优解,则必须执行步骤(4)。此时,在步骤(3)中计算最优值时,通常需记录更多的信息,以便在步骤(4)中,根据所记录的信息,快速构造出一个最优解。基本步骤2020/1/1734三、动态规划问题的特征动态规划算法的有效性依赖于问题本身所具有的两个重要性质:1、最优子结构:当问题的最优解包含了其子问题的最优解时,称该问题具有最优子结构性质。2、重叠子问题:在用递归算法自顶向下解问题时,每次产生的子问题并不总是新问题,有些子问题被反复计算多次。动态规划算法正是利用了这种子问题的重叠性质,对每一个子问题只解一次,而后将其解保存在一个表格中,在以后尽可能多地利用这些子问题的解。2020/1/1735课后任务:一、DIY在线作业(4):《ACM程序设计》在线作业(4)——动态规划(第一部分)二、常规练习(包含以上作业)1003、1466、1087、1176、2084、1159、11601058、1069、2059、21512020/1/1736下一讲:计算几何2020/1/1737WelcometoHDOJThankYou~
本文标题:其它技巧lecture动态规划
链接地址:https://www.777doc.com/doc-3127982 .html