- 4
- 0
- 约1.05万字
- 约 13页
- 2017-01-06 发布于重庆
- 举报
浅谈记忆化搜索.
浅谈记忆化搜索
江苏省常州高级中学 吴景岳
【摘要】
搜索和动态规划是信息学中的两大重要算法。它们各有自己的优点和缺点。针对它们的优缺点,一个新的算法——“记忆化搜索”产生了。它采用了搜索的形式与动态规划的思想,扬长避短,在解决某些题目时,有非常出色的表现。它在信息学竞赛中也有举足轻重的地位,NOI2001的cannon与NOI2002的dragon都使用到了这个算法。这篇论文着重分析了搜索、动态规划和记忆化搜索之间的联系和区别,以及各自的优缺点,并通过几个例子使得大家对记忆化搜索有一个初步的了解。
【关键字】
重叠子问题 拓扑关系 形式+思想
【目录】
搜索
搜索树
例子——words
效率低下的原因——重叠子问题
动态规划
基本原理——最优子结构、无后效性
拓扑关系(例子——最长路径)
记忆化搜索
记忆化搜索=搜索的形式+动态规划的思想
记忆化深度优先搜索
程序框架
例子——words
记忆化宽度优先搜索
程序框架
例子——cannon
缺点分析
总结
【正文】
搜索
搜索树
一道搜索题目拿到手,我们往往要弄清楚这样一些问题:以什么作为状态?这些状态之间又有什么样的关系?其实,在这样的思考过程中,我们已经不知不觉地将一个具体的问题抽象成了一个图论的模型——树。
状态对应着顶点,状态之间的关系(或者说从一个状态到另一个状态的形成过程)对应着边。这样的一棵树就叫做搜索树。初始状态对应着根结点,目标状态对应着目标结点。我们的任务就是找到一条从根结点到目标结点的路径——一个成功的解。
例子——words
[问题描述]
Io和Ao在玩一个单词游戏。他们轮流说出一个仅包含元音字母的单词,并且后一个单词的第一个字母必须与前一个单词的最后一个字母一致。游戏可以从任何一个单词开始。
任何单词禁止说两遍,游戏中只能使用给定词典中含有的单词。
游戏的复杂度定义为游戏中所使用的单词的长度总和。
编写程序求出使用一本给定的词典来玩这个游戏所能达到的游戏最大可能复杂度。
数据规模限制:单词总数不超过16,单词长度不超过100。
[算法分析]
这是省集训队冬令营的一道题目,当时大多数同学都用了搜索。让我们看看他们是如何搜索的。
状态:
现在说到哪一个单词+已经说过的单词集合
我们将状态表示为(I,S),表示说到了单词I,已经说过的单词集合为S。
状态之间的关系:
(I,S)-(j,S1) (S1=S+j)的条件为单词J不在集合S中,并且单词J可以接在单词I后面。
但是,这样搜索效率是不会高的。所以,当时很多人都是因为超时,最后三个点没有出来。那么,搜索效率低下的根本原因是什么呢?
重叠子问题
在一些复杂的搜索问题中,搜索树是极其庞大的,结点数量非常多,结点之间的关系也非常复杂,这是导致搜索算法效率低下的重要原因。其实,在有的情况下,状态的总数并没有多少,有可能很多结点表示的都是同一个状态,我们把这样的状态叫做“重叠子问题”。由于搜索算法本身性质的制约,它不能把这些重叠子问题记录下来,只能不知疲倦地继续访问下去,不断遇到这些讨厌的重叠子问题。显然,如果能不把时间放在处理重叠子问题上,算法的效率将发生一个质的飞跃。那么有没有这样一种可以避免重复地处理重叠子问题的算法呢?这就是——
动态规划
基本原理
动态规划是大家极为熟悉的一种算法,实际上一道动态规划的问题也可以转化为求解搜索树的问题。同样是搜索树,动态规划却比搜索算法高效很多,这是因为它把每个状态的最优值都记录了下来,于是成功地避免了重复地处理重叠子问题。不过,动态规划的使用是要满足两个基本条件的:
最优子结构
用动态规划解决一个问题的第一步是刻划一个最优解的结构。如果一个问题的最优解中包含了子问题的最优解,我们就说这个问题具有最优子结构。
无后效性
动态规划的过程是一个状态转移的过程:不断地从一个已知的状态出发,推出一个新的状态。但是,如果新的状态又能够推出前面的状态(影响前面的状态),那么这样的状态划分就具有了后效性。动态规划能够成功的一个必要条件就是无后效性。
拓扑关系
我们同样地对动态规划问题进行抽象:状态-结点,状态之间的关系-边。这样,一个动态规划的问题就可以抽象成为一个图。因为动态规划是满足无后效性的,这样的图必将是一个有向无环图。在动态规划中,状态之间有着严格的递推关系,我们必须确定哪些状态必须先推出,哪些应当后推出。这就称为拓扑关系。将点(状态)按照拓扑关系排序,就叫做拓扑排序。拓扑排序保证:除初始状态以外,每个状态都可以由它前面的状态推出。
举一个例子:下图是一个有向无环图,求从顶点1到顶点6的最长路径。(规定边的方向从左到右)
我们将从起点(顶点1)开始到某个顶点的最长路
您可能关注的文档
最近下载
- Xikong西莱克低温机控制板SHXK814用户手册.pdf
- 爱迪生牛顿大发明攻略.doc VIP
- 重庆天齐锂电新材料有限公司新建1000吨_年高能锂电材料电池级金属锂项目环评报告.pdf VIP
- 朗文3A复习资料及垃圾分类作文8篇.doc VIP
- DB65T 3694-2015 现行哈萨克文与西里尔哈萨克文编码字符转换规则.docx VIP
- TGXAS 1044-2025《中医护理三级查房规范》(发布稿).pdf VIP
- 华为云服务登录.doc VIP
- 采砂场工业用水水资源论证论证表详解.doc VIP
- Onkyo安桥TX-NR828中文说明书.pdf
- 采砂场工业用水水资源论证论证表分析报告.doc
原创力文档

文档评论(0)