杭电ACM课件(lecture_09)搜索入门080427.ppt

  1. 1、本文档共38页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
杭电ACM课件(lecture_09)搜索入门080427

第五类 搜索题 根据“信息学初学者之家”网站的统计,Ural(俄罗斯的Ural州立大学的简称 ,有名的Ural Online Problem Set 就是该校的系统)的题目类型大概呈如下的分布: 搜索 动态规划 贪心 构造 图论 约10% 约15% 约5% 约5% 约10% 计算几何 纯数学题 数据结构 其它 约5% 约20% 约5% 约25% ——摘自《ACM竞赛之新人向导 》 “算法中最基本和常用的是搜索,这里要说的是,有些初学者在学习这些搜索基本算法是不太注意剪枝,这是十分不可取的,因为所有搜索的题目给你的测试用例都不会有很大的规模,你往往察觉不出程序运行的时间问题,但是真正的测试数据一定能过滤出那些没有剪枝的算法。 实际上参赛选手基本上都会使用常用的搜索算法,题目的区分度往往就是建立在诸如剪枝之类的优化上了。 ” 什么是搜索算法呢? 搜索算法是利用计算机的高性能来有目的地穷举一个问题的部分或所有的可能情况,从而求出问题的解的一种方法。 搜索过程实际上是根据初始条件和扩展规则构造一棵解答树并寻找符合目标状态的节点的过程。 预热一下:二分查找 2 3 4 5 6 8 12 20 32 45 65 74 86 95 100 查找示意图: 思考: 1、在一百万个元素里查找某个元素大约需要比较多少次? 举例分析 从简单的字符串搜索讲起 HDOJ_1238 Substrings HDOJ_1238 Substrings 题目分析: 这是一道入门级别的搜索题,基本思想比较简单,但是如果用最朴素的算法,可能会超时如何降低算法的复杂度呢? 下面的算法如何: 先将字符串按长度从短到长排序,枚举最短的字符串的子串,判断是否都是别的字符串的子串,求出最大长度即可。 说明: 本题除了可以练习基本搜索算法,也是练习字符串处理的好题目,题中用到的相关知识点有: 求反串 求子串 字符串查找 求字符串长度 再来一道数值型搜索题 HDOJ_1239 获取有用信息 1.给定整数m,a,b(4 m = 100000 and 1 = a = b = 1000) 2.需要找到两个数(不妨设为p,q)满足以下条件: p,q均为质数; p*q=m 并且尽可能接近m; a/b = p/q = 1;(p、q的比例约束) 算法分析 1.典型的搜索 从所有可能的p,q中寻找满足条件的一对 2.p,q的要求 p,q均为质数,且p=q=100000; 3.按上述思想流程应为: a.从1—100000中搜出质数 b.两层循环,试遍所有的组合(p,q可能相等) c.每种组合去判断是否符合条件,如是,将p*q与当前最大值比较,判断,保存 面临的问题: 超时! 从1—100000的质数运算约为1e+8,而这只是准备工作。 因此,如不加以分析简化此题无法在规定时间内出解 深入分析: p,q的范围其实可在2—50000(why?) 然而,这是最小的范围吗? 考虑大于10000的某个质数,不妨设为Q,另一个质数为P,则: 如果P10,P/Q0.001 如果P10,P*Q100000 而考虑到a,b的取值范围(1=a=b=1000) 可知min(a/b)=0.001 同时,要求: p*q=m=100000 所以无论如何质数都不能超过10000 搜索时的技巧: 搜索顺序很重要。建议从大往小搜 (num:质数的个数 ) for (i=num-1;i=0;i--) for (j=i;j=num-1;j++) …… 注意剪枝: If ( a[j]m || a[j]*a[i]m || ( (double)a[i]/a[j])s ) …… 二、典型搜索——迷宫搜索 例1:是否存在路径 思路分析 (1) if( 当前位置是界外) 返回上一步; (2) if (当前位置是出口)flag=1; (3) if(flag==1) return; (4)尝试相邻四个可能位置{ if( 如果这个位置不是墙) { (a) 这个位置为墙标志X,表示已走过 (b) 从这个位置开始深度优先搜索 (c) 把该方格仍置为空格 } } 实现 char map[9][9]; flag=0; int dir[4][2]={{0,-1},{0,1},{1,0},{-1,0}};

文档评论(0)

dajuhyy + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档