动态规划解题策略:杭电ACM课件解析
需积分: 16 160 浏览量
更新于2024-08-18
收藏 416KB PPT 举报
"这篇资料是关于ACM竞赛中的动态规划讲解,主要分析了两个问题:动态规划求解老鼠抓猫问题以及计算直线交点数的问题。资料来自于杭电的课程,并涉及动态规划基础和实际应用。"
在动态规划中,我们通常会遇到一个问题的最优解可以通过构建子问题的最优解来获得。在这个案例中,讨论了一个关于老鼠抓猫的经典问题。问题描述如下:给定一组老鼠,每只老鼠有两个属性,重量W和速度S。我们需要找到最长的一串老鼠,使得序列中的每只老鼠都比它后面的老鼠重,并且速度慢。这是一种基于排序的动态规划问题。
首先,我们按照重量W对老鼠进行升序排序,然后按照速度S降序排列。这样,每只老鼠都是重量最大的,但速度不是最快的老鼠。
接下来定义动态规划的状态f[i],它表示从Mice[0]到Mice[i]这一段中,最长的符合条件的老鼠序列长度。对于f[i],我们可以遍历前面的j(1 <= j < i),如果Mice[i]的重量大于Mice[j]且速度小于Mice[j],那么f[i]可以基于f[j]加1来扩展。初始状态设置为f[i] = 1,意味着每只老鼠至少可以单独形成一个长度为1的序列。
此外,资料还引入了一个计算直线交点数的问题。当平面内有n条直线,没有三条共点时,我们不仅要找到所有直线最多可能的交点数,还需要找出所有可能的不同交点数情况。通过列举小规模问题(如n=1,2,3)的解,可以发现动态规划的思路:对于第n条直线,我们可以考虑它与前面n-1条直线的交点情况。通过分析n=4的情况,我们归纳出公式,即m条直线的交点方案数由m-r条平行线与r条直线交叉的交点数加上r条直线之间的交点方案数构成。
这份资料提供了动态规划在解决实际问题中的应用示例,包括排序和状态转移矩阵的构建,以及如何通过归纳法解决特定问题。对于ACM竞赛的参赛者和学习动态规划的初学者来说,这些都是非常有价值的学习材料。
121 浏览量
273 浏览量
537 浏览量
807 浏览量
2014-11-26 上传
2012-04-12 上传
130 浏览量
123 浏览量
2010-03-21 上传
永不放弃yes
- 粉丝: 917
- 资源: 2万+
最新资源
- VUTTR:前端应用程序VUTTR(非常有用的工具,要记住)。 Aplicaçãoéumsrepositóriopara gerenciar ferramentas com seuspectivos标题,链接,说明和标签
- nake:将您的Nim构建描述为任务
- 科技发展中心网页模板
- nodejs-typeorm-upload:NodeJSTypescript + typeorm和文件上传以导入数据的示例
- Document Library Automation-crx插件
- learn_tarscpp.7z
- asp.netERP客户关系系统设计程序源代码说明制造标准采购计划库存销售成本车间管理应收应付财务工资
- jquery.motionnotion:一个 jQuery 插件,它允许 CSS3 动画在核心 jQuery 操作和可见性功能(如追加、删除、显示和隐藏)上发生和完成
- neotrackapp
- 5A06 铝合金薄板自动化焊接工艺研究.rar
- IKAnalyzer中文分词.rar
- Cognifirm-crx插件
- 全国手机号码归属地信息,包含移动联动电信
- go-wkhtmltopdf:wkhtmltopdf Go绑定和HTML到PDF转换的高级界面
- 绿色幼儿教育机构网页模板
- vagrant:在你的项目中使用 Vagrant 的基本示例