2020/1/201ACM程序设计计算机学院刘春英2020/1/202今天,你了吗?2020/1/203每周一星(3):liuzewei2020/1/204第四讲动态规划(1)(Dynamicprogramming)2020/1/205先热身一下——2020/1/206(1466)计算直线的交点数问题描述:平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数。输入:n(n=20)输出:每个测试实例对应一行输出,从小到大列出所有相交方案,其中每个数为可能的交点数。样例输入4样例输出034562020/1/207思考2分钟:如何解决?2020/1/208初步分析:我们将n条直线排成一个序列,直线2和直线1最多只有一个交点,直线3与直线1和直线2最多有两个交点…….,直线n和其他n-1条直线最多有n-1个交点,由此得出n条直线互不平行且无三线共点的最多交点数max=1+2+……(n-1)=n(n-1)/2,但本题不这么简单,因为问题问的是:这些直线有多少种不同的交点数?2020/1/209容易列举出N=1,2,3的情况:00,10,2,3如果已知N的情况,我们来分析加入第N条直线的情况(这里N=4):1、第四条与其余直线全部平行=无交点;2、第四条与其中两条平行,交点数为(n-1)*1+0=3;3、第四条与其中一条平行,这两条平行直线和另外两点直线的交点数为(n-2)*2=4,而另外两条直线既可能平行也可能相交,因此可能交点数为:(n-2)*2+0=4或者(n-2)*2+1=54、第四条直线不与任何一条直线平行,交点数为:(n-3)*3+0=3或者(n-3)*3+2=5或者(n-3)*3+3=6即n=4时,有0个,3个,4个,5个,6个不同交点数。2020/1/2010从上述n=4的分析过程中,我们发现:m条直线的交点方案数=(m-r)条平行线与r条直线交叉的交点数+r条直线本身的交点方案=(m-r)*r+r条之间本身的交点方案数(1=r=m)2020/1/2011一、数塔问题有形如下图所示的数塔,从顶部出发,在每一结点可以选择向左走或是向右走,一直走到底层,要求找出一条路径,使路径上的值最大。2020/1/2012用暴力的方法,可以吗?2020/1/2013试想一下:这道题如果用枚举法(暴力思想),在数塔层数稍大的情况下(如31),则需要列举出的路径条数将是一个非常庞大的数目(2^30=1024^310^9=10亿)。2020/1/2014所以,不可以如此暴力!!!2020/1/2015考虑一下:从顶点出发时到底向左走还是向右走应取决于是从左走能取到最大值还是从右走能取到最大值,只要左右两道路径上的最大值求出来了才能作出决策。同样,下一层的走向又要取决于再下一层上的最大值是否已经求出才能决策。这样一层一层推下去,直到倒数第二层时就非常明了。如数字2,只要选择它下面较大值的结点19前进就可以了。所以实际求解时,可从底层开始,层层递进,最后得到最大值。结论:自顶向下的分析,自底向上的计算。2020/1/2016Understand?2020/1/2017二、思考题:最长有序子序列I012345678Num[I]147258369请回答:穷举(暴力)方法的时间复杂度是多少?2020/1/2018解决方案:I012345678Num[I]147258369F[I]1232343452020/1/2019三、HDOJ_1160FatMouse'sSpeed题目链接SampleInput60081300600021005002000100040001100300060002000800014006000120020001900SampleOutput445972020/1/2020题目分析:设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/2021Qestion:两个问题有本质区别吗?2020/1/2022思考(期末考试题):SuperJumping!Jumping!Jumping!2020/1/2023解题思路?2020/1/2024四、HDOJ_1159CommonSubsequence题目链接SampleInputabcfbcabfcabprogrammingcontestabcdmnpSampleOutput4202020/1/2025请先计算暴力算法的时间复杂度:(当然是指最坏情况!)2020/1/2026abcfbca111111b122222f122333c123334a123334b123344辅助空间变化示意图2020/1/2027子结构特征: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])2020/1/2028理论总结2020/1/2029一、动态规划的基本思想2020/1/2030如果各个子问题不是独立的,不同的子问题的个数只是多项式量级,如果我们能够保存已经解决的子问题的答案,而在需要的时候再找出已求得的答案,这样就可以避免大量的重复计算。由此而来的基本思路是,用一个表记录所有已解决的子问题的答案,不管该问题以后是否被用到,只要它被计算过,就将其结果填入表中。一、动态规划的基本思想2020/1/2031二、动态规划的基本步骤动态规划算法通常用于求解具有某种最优性质的问题。在这类问题中,可能会有许多可行解。每一个解都对应于一个值,我们希望找到具有最优值(最大值或最小值)的那个解。设计一个动态规划算法,通常可以按以下几个步骤进行:2020/1/2032(1)找出最优解的性质,并刻画其结构特征。(2)递归地定义最优值。(3)以自底向上的方式计算出最优值。(4)根据计算最优值时得到的信息,构造一个最优解。其中(1)——(3)步是动态规划算法的基本步骤。在只需要求出最优值的情形,步骤(4)可以省去。若需要求出问题的一个最优解,则必须执行步骤(4)。此时,在步骤(3)中计算最优值时,通常需记录更多的信息,以便在步骤(4)中,根据所记录的信息,快速构造出一个最优解。2020/1/2033三、动态规划问题的特征动态规划算法的有效性依赖于问题本身所具有的两个重要性质:1、最优子结构:当问题的最优解包含了其子问题的最优解时,称该问题具有最优子结构性质。2、重叠子问题:在用递归算法自顶向下解问题时,每次产生的子问题并不总是新问题,有些子问题被反复计算多次。动态规划算法正是利用了这种子问题的重叠性质,对每一个子问题只解一次,而后将其解保存在一个表格中,在以后尽可能多地利用这些子问题的解。2020/1/2034思考:免费馅饼2020/1/2035如何解决?请发表见解2020/1/2036AnyQuestion?2020/1/2037附录:DP练习题(HDOJ):1003、1087、1159、1160、11761024、1025、1058、1069、10811074、1157、1158、14661078、1080、11141203、1294、1227、12231500、1501、1502、15031505、1506、1510、20592020/1/2038课后一定要练习!DP”相-当-”重要!2020/1/2039有志于参加竞赛的同学,加油!!!2020/1/2040ACM,天天见!