- 1、本文档共16页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
搜索剪枝常见方法与技巧
搜索剪枝常见方法与技巧
关键字 搜索方法,剪枝
摘要
搜索是计算机解题中常用的方法,它实质上是枚举法的应用。由于它相当于枚举法,所以其效率是相当低的。因此,为了提高搜索的效率,人们想出了很多剪枝的方法,如分枝定界,启发式搜索等等。在竞赛中,我们不仅要熟练掌握这些方法,而且要因地制宜地运用一些技巧,以提高搜索的效率。
正文
搜索的效率是很低的,即使剪枝再好,也无法弥补其在时间复杂度上的缺陷。因此,在解题中,除非其他任何方法都行不通,才可采用搜索。
既然采用了搜索,剪枝就显得十分的必要,即使就简简单单的设一个槛值,或多加一两条判断,就可对搜索的效率产生惊人的影响。例如N后问题,假如放完皇后再判断,则仅仅只算到7,就开始有停顿,到了8就已经超过了20秒,而如果边放边判断,就算到了10,也没有停顿的感觉。所以,用搜索就一定要剪枝。
剪枝至少有两方面,一是从方法上剪枝,如采用分枝定界,启发式搜索等,适用范围比较广;二是使用一些小技巧,这类方法适用性虽不如第一类,有时甚至只能适用一道题,但也十分有效,并且几乎每道题都存在一些这样那样的剪枝技巧,只是每题有所不同而已。
问题一:(最短编号序列)
表A和表B各含k(k=20)个元素,元素编号从1到k。两个表中的每个元素都是由0和1组成的字符串。(不是空格)字符串的长度=20。例如下表的A和B两个表,每个表都含3个元素(k=3)。
元素编号 字符串 1 1 2 10111 3 10 表A 表B
元素编号 字符串 1 111 2 10 3 0
对于表A和表B,存在一个元素编号的序列2113,分别用表A中的字符串和表B 中的字符串去置换相应的元素编号,可得相同的字符串序列101111110,见下表。
元素编号序列 2 1 1 3 用表A的字符串替换 10111 1 1 10 用表B的字符串替换 10 111 111 0 对表A和表B,具有上述性质的元素编号序列称之为S(AB)。对于上例S(AB)=2113。
编写程序:从文件中读入表A和表B的各个元素,寻找一个长度最短的具有上述性质的元素编号序列S(AB)。(若找不到长度=100的编号序列,则输出“No Answer”。
对于这道题,因为表A和表B不确定,所以不可能找到一种数学的方法。因为所求的是最优解,而深度优先搜索很容易进入一条死胡同而浪费时间,所以必须采用广度优先搜索的方法。但是,广度优先搜索也有其缺陷。当表A和表B中的元素过多是,扩展的结点也是相当多的,搜索所耗费的时间也无法达到测试的要求。为了解决这个问题,就必须对搜索的算法加以改进。分枝限界似乎不行,因为无法确定代价。而且,由于目标不确定,也无法设定估价函数。但是,因为此题的规则既可以正向使用,又可以逆向使用,于是便可以采用双向搜索。
在大方法确定后,算法的框架就已经基本形成,但即使如此,算法也还有可改进的地方。
存储当前的A串和B串是很费空间的,但因为A串和B串的大部分相同,故只需记录不同部分,并作个标记。再换成动态存储。
为了保证两个方向扩展结点的速度相对平衡,可以采取每次扩展结点数较少的方向,而不是两方向轮流扩展。
如此一来,搜索的效率就比单纯的广度优先搜索有了明显的提高。
(附程序sab.pas)
有时,搜索也会有不同的搜索方法(如多处理机调度问题),也会产生不同的效率。
问题二:(任务安排)
N个城市,若干城市间有道路相连,一辆汽车在城市间运送货物,总是从城市1出发,又回到城市1。该车每次需完成若干个任务,每个任务都是要求该车将货物从一个城市运送至另一个。例如若要完成任务2-6,则该车一次旅程中必含有一条子路径。先到2,再到6。
如下图所示,如果要求的任务是2-3,2-4,3-1,2-5,6-4,则一条完成全部任务的路径是1-2-3-1-2-5-6-4-1。
4
1 2 6
5
3 7
编程由文件读入道路分布的领接矩阵,然后对要求完成的若干任务,寻找一条旅行路线,使得在完成任务最多的前提下,经过的城市总次数最少。如上例中经过城市总次数为8,城市1和2各经过2次均以2次计(起点不计),N60。
这道题,因为很难找到数学规律,便只有采用搜索的方法。
首先,第一感觉便是:从城市i出发,便搜索所有相邻的城市,再根据当前所处的城市,确定任务的
您可能关注的文档
- 推土机技术参数及数量要求表.doc
- 推料机维护检修规程(已审).doc
- 推进基于课程标准的教学与评价讲座.docx
- 提供躲藏处所构成何罪探讨与研究.doc
- 提升产品体验愉悦性的十个方法.docx
- 提升微波以太网传输带宽的解决方案.doc
- 提升系统设计计算及安装说明书.doc
- 提盐工艺可行性分析报告.doc
- 提高售后技术能力培训方案.doc
- 提高学生学习效率实验研究成果.doc
- 比较确定性身体模拟性能机器人群生物风格随机觅食策略参考.pdf
- 干部教育培训计划方案.pdf
- 参考软件包com realaction view答案t9adapter java.pdf
- 雅思基础阅读主旨句寻找set 10.pdf
- 妇产科护理学2017-全练习fckhl lx1403.pdf
- 参考详解任务.pdf
- 恐龙送出课文分级阅读.pdf
- 新预训练任务竞争边缘品牌产品测验pre training nhf 1培训前NHF1.pdf
- 灰色解剖剧集脚本季眨眼原始airdateomy s6剧本blink.pdf
- 综合synway cti系列-1220d pci cas三汇shd006intro.pdf
最近下载
- 华为培训教材存储产品概论.ppt
- Q31 0115000140C043_立邦反射隔热涂料.pdf VIP
- 首届智能用电运营工技能竞赛理论考试题库-下(多选、判断题汇总).docx VIP
- 《输配电及用电工程》理论考试题库-下(多选、判断题汇总).docx VIP
- 《经皮去肾交感神经术治疗高血压专家建议2025》解读.pptx VIP
- 公立医院经济管理年活动自评报告三.docx VIP
- 关于深入推进移风易俗工作的通知.doc VIP
- 普通高中通用技术学生设计作品图文材料.pdf VIP
- 2024年《输配电及用电工程》理论考试题库(浓缩400题).docx VIP
- 考研英语2005年-2018年英语二答案.docx VIP
文档评论(0)