版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、2022/9/291今天,你 了吗?AC2022/9/271今天,你 了吗?AC2022/9/292每周一星(3):混沌的云Knight 2022/9/272每周一星(3):混沌的云Knight 2022/9/293第四讲动态规划(1) (Dynamic programming)2022/9/273第四讲动态规划(1) 2022/9/294先热身一下2022/9/274先热身一下2022/9/295(1466)计算直线的交点数问题描述: 平面上有n条直线,且无三线共点,问这些直线能有多少种不同交点数。输入:n(n=20)输出:每个测试实例对应一行输出,从小到大列出所有相交方案,其中每个数为可能
2、的交点数。样例输入4样例输出0 3 4 5 62022/9/275(1466)计算直线的交点数问题描述:2022/9/296初步分析:我们知道:n条直线互不平行且无三线共点的最多交点数max=1+2+(n-1)=n(n-1)/2,但本题不这么简单,因为问题问的是:这些直线有多少种不同的交点数?2022/9/276初步分析:我们知道:2022/9/297思考2分钟:如何解决?2022/9/277思考2分钟:如何解决?2022/9/298然后,假设=n-1的情况都已经知道分析思路 首先,容易列举出N=1,2,3的情况:00,10,2,32022/9/278然后,假设 0+4*0+0=0;2、第四条
3、与其中两条平行,交点数为0+(n-1)*1+0=3;3、第四条与其中一条平行,这两条平行直线和另外两点直线的交点数为(n-2)*2=4,而另外两条直线既可能平行也可能相交,因此可能交点数为: 0+(n-2)*2+0=4 或者 0+(n-2)*2+1=5 4、 第四条直线不与任何一条直线平行,交点数为: 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的情况:2022/9/2710我们来分析加入第N条直线的情况(这里以2022/9/2911从上述n=4的分析过程中,我们发现:m条直线的交点方
4、案数=(m-r)条平行线与r条直线交叉的交点数 + r条直线本身的交点方案=(m-r)*r+r条之间本身的交点方案数(0=r 109=10亿)。试想一下:2022/9/2714这道题如果用枚举法(暴力思想),在数2022/9/2915 拒绝暴力,倡导和谐2022/9/2715 拒绝暴力,倡导和谐2022/9/2916从顶点出发时到底向左走还是向右走应取决于是从左走能取到最大值还是从右走能取到最大值,只要左右两道路径上的最大值求出来了才能作出决策。同样,下一层的走向又要取决于再下一层上的最大值是否已经求出才能决策。这样一层一层推下去,直到倒数第二层时就非常明了。如数字2,只要选择它下面较大值的结
5、点19前进就可以了。所以实际求解时,可从底层开始,层层递进,最后得到最大值。结论:自顶向下的分析,自底向上的计算。考虑一下:2022/9/2716从顶点出发时到底向左走还是向右走应2022/9/2917二、思考题:最长有序子序列I012345678NumI1472583692022/9/2717二、思考题:最长有序子序列I012342022/9/2918解决方案:I012345678NumI147258369FI1232343452022/9/2718解决方案:I012345678Num2022/9/2919三、1160 FatMouses Speed Sample Input6008 130
6、0 6000 2100 500 2000 1000 4000 1100 3000 6000 2000 8000 1400 6000 1200 2000 1900 Sample Output4 4 5 9 72022/9/2719三、1160 FatMouses 2022/9/2920题目分析:设Micei.W表示第i只老鼠的重量,Micei.S表示第i只老鼠的速度。我们先对Mice进行排序,以W为第一关键字,从小到大,S为第二关键字,从大到小。设fi为Micei至Micen最长的序列长度。考虑某一个fi,则有: fi = max(fi, fj+1) (1=j Micej.W,Micei.S M
7、icej.S) 其中,初始条件为fi=1 (i=1, 2, ., n)。2022/9/2720题目分析:设Micei.W表示第i2022/9/2921Qestion:两个问题有本质区别吗?2022/9/2721Qestion:两个问题有本质区别吗2022/9/2922思考(期末考试题):Super Jumping! Jumping!Juping! 2022/9/2722思考(期末考试题):Super Ju解题思路?解题思路?2022/9/2924四、1159 Common SubsequenceSample Inputabcfbc abfcabprogramming contest abcd
8、mnp Sample Output 4 2 02022/9/2724四、1159 Common Sub2022/9/2925abcfbca111111b122222f122333c123334a123334b123344辅助空间变化示意图2022/9/2725abcfbca111111b122222022/9/2926f(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)就得到所要求的解
9、了.f(i-1,j-1)+1 (ai=bj)max(f(i-1,j),f(i,j-1) (ai!=bj) 子结构特征:2022/9/2726f(i,j)= f(i-1,j-1)2022/9/2927思考:免费馅饼 2022/9/2727思考:免费馅饼 2022/9/2928如何解决?请发表见解 2022/9/2728如何解决?请发表见解 Any question?Any question?2022/9/2930理论小结2022/9/2730理论小结2022/9/2931如果各个子问题不是独立的,不同的子问题的个数只是多项式量级,如果我们能够保存已经解决的子问题的答案,而在需要的时候再找出已求得
10、的答案,这样就可以避免大量的重复计算。由此而来的基本思路是,用一个表记录所有已解决的子问题的答案,不管该问题以后是否被用到,只要它被计算过,就将其结果填入表中。 一、动态规划的基本思想 2022/9/2731如果各个子问题不是独立的,不同的子问2022/9/2932二、动态规划的基本步骤 动态规划算法通常用于求解具有某种最优性质的问题。在这类问题中,可能会有许多可行解。每一个解都对应于一个值,我们希望找到具有最优值(最大值或最小值)的那个解。设计一个动态规划算法,通常可以按以下几个步骤进行: 2022/9/2732二、动态规划的基本步骤 2022/9/2933(1)找出最优解的性质,并刻画其结
11、构特征。(2)递归地定义最优值。(3)以自底向上的方式计算出最优值。(4)根据计算最优值时得到的信息,构造一个最优解。其中(1)(3)步是动态规划算法的基本步骤。在只需要求出最优值的情形,步骤(4)可以省去。若需要求出问题的一个最优解,则必须执行步骤(4)。此时,在步骤(3)中计算最优值时,通常需记录更多的信息,以便在步骤(4)中,根据所记录的信息,快速构造出一个最优解。基本步骤 2022/9/2733(1)找出最优解的性质,并刻画其结构特2022/9/2934三、动态规划问题的特征 动态规划算法的有效性依赖于问题本身所具有的两个重要性质:1、最优子结构:当问题的最优解包含了其子问题的最优解时,称该问题具有最优子结构性质。2、重叠子问题:在用递归算法自顶向下解问题时,每次产生的子问题并不总是新问题,有些子问题被反复计算多次。动态规划算法正是利用了这种子问题的重叠性质,对每一个子问题只解一次,而后将其解保存在一个表格中,在以后尽可能多地利用这些子问题的解。2022/9/2734三、动态规划问题的特征 动态规划算2022/9/2935课后任务:一、DIY在线作业(4):ACM程序设计在线作业(4) 动态规划(第一部分) 二、常规练习(包含以上作业)100
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 某塑料模具厂工艺流程办法
- 2026年车辆中心面试运营管理题
- 中石化油田电力岗2026校园招聘问答
- 2026年志愿者反诈劝阻技巧与法律风险测试
- 2026年垃圾焚烧厂运行岗面试题
- 2026年街道诚信建设万里行活动试题
- 2026年气象信息值班岗模拟题
- 2026年安全总监岗位面试仿真题与高管面试技巧
- 2026年社区网格疫情防控网格化知识题
- XX高中2026年春季学生学业生涯规划指导讲座校长致辞
- 2026年公立医院检验科招聘试题(附答案)
- 2026年自然资源统一确权登记知识测试题
- 2026年二级注册计量师(计量法律法规及综合知识)考试试题及答案
- 2025年合肥兴泰金融控股(集团)有限公司招聘23人笔试参考题库附带答案详解
- 太钢不锈钢产品手册
- 德力西CDI9100-G系列变频器说明书
- GB/T 12916-2024船用金属螺旋桨技术条件
- unit-6-where-is-the-s-leading-us市公开课一等奖省赛课微课金奖课
- 鲁滨逊漂流记读书交流会
- 干式变压器培训课件
- 数据清洗课件-第6章-ETL数据清洗与转换
评论
0/150
提交评论