- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
学科竞赛编程C++NOIPNOIIOI
深度优先搜索?深度优先搜索是一种在开发爬虫早期使用较多的方法。它的目的是要达到被搜索结构的叶结点(即那些不包含任何超链的HTML文件)。在一个HTML文件中,当一个超链被选择后,被链接的HTML文件将执行深度优先搜索,即在搜索其余的超链结果之前必须先完整地搜索单独的一条链。深度优先搜索沿着HTML文件上的超链走到不能再深入为止,然后返回到某一个HTML文件,再继续选择该HTML文件中的其他超链。当不再有其他超链可选择时,说明搜索已经结束。
深度优先遍历图的方法是,从图中某顶点v出发:(1)访问顶点v;(2)依次从v的未被访问的邻接点出发,对图进行深度优先遍历;直至图中和v有路径相通的顶点都被访问;(3)若此时图中尚有顶点未被访问,则从一个未被访问的顶点出发,重新进行深度优先遍历,直到图中所有顶点均被访问过为止。当然,当人们刚刚掌握深度优先搜索的时候常常用它来走迷宫.
boolvisited[MaxVnum];voidDFS(GraphG,intv){visited[v]=true;//从V开始访问,flag它printf(%d,v);//打印出Vfor(intj=0;jG.vexnum;j++)if(G.arcs[v][j]==1visited[j]==false)//这里可以获得V未访问过的邻接点DFS(G,j);//递归调用,如果所有节点都被访问过,就回溯,而不再调用这里的DFS}voidDFSTraverse(GraphG){for(intv=0;vG.vexnum;v++)visited[v]=false;//刚开始都没有被访问过for(intv=0;vG.vexnum;++v)if(visited[v]==false)//从没有访问过的第一个元素来遍历图DFS(G,v);}
广度优先搜索广度优先搜索算法(又称宽度优先搜索),简称BFS。BFS每次都先将搜索树每一层的所有节点全部访问完毕后再访问下一层,因此也被称作“按层搜索”。
广度优先算法的核心思想:从初始节点开始,应用算符生成的第一层节点,检查目标节点是否在这些后继节点中,若没有,再用产生式规则将所有第一层的节点逐一扩展,得到第二层节点,并逐一检查第二层节点中是否包含目标节点,若没有,再用算符逐一扩展第二层的所有节点…,如此依次扩展,检查下去,直到发现目标节点为止。即:1.从图中的某一顶点v0开始,先访问v0;2.访问所有与v0相邻的顶点v1,v2,…,vt;3.依次访问与v1,v2,…,vt相邻接的所有未曾访问过的顶点;4.循环以往,直至所有的顶点都被访问过为止;这中搜索的次序体现沿层次向横向扩展的趋势,所以称之为广度优先搜索。
intbfs(){初始化,初始状态存入队列;队列首指针head=0;尾指针tail=1;do{指针head后移一位,指向待扩展结点;for(inti=1;i=max;++i){//max为产生子节点的规则数if(子节点符合条件){ tail指针增1,把新结点存入列尾;if(新结点与原已产生结点重复)删去该结点(取消入队,tail减1);elseif(新结点是目标结点)输出并退出;}}}while(headtail);//队列为空}
像科学家一样思考像工程师一样解决问题
您可能关注的文档
- 高一上学期化学人教版必修第一册“位—构—性”与元素的综合推断课件.pptx
- 高一上学期统编版必修中外历史纲要上第四单元明清中国版图的奠定与面临的挑战课件.pptx
- 高中历史统编版一轮复习第一单元从中华文明到统一多民族封建国家的建立与巩固复习课件.pptx
- 高中日语华东理工版新编日语教程第十四课花火大会课件.pptx
- 高中日语新版标准日本语初级下册第42课+テレビをつけたまま,出かけてしまいました+课件.pptx
- 高中通用技术苏教版必修《技术与设计》第三章发现与明确问题课件.pptx
- 高中通用技术粤科版必修《技术与设计》第三章火情我控制消防灭火系统的设计课件.pptx
- 高中信息学奥赛CSP-JS+NOIP—入门组C++知识点讲解)第14讲链表.pptx
- 高中信息学奥赛CSP-JS+NOIP—提高组C知识点讲解)第13讲预处理器.pptx
- 公式法求抛物线y=ax2+bx+c的顶点坐标课件人教版数学九年级上册.pptx
- 考点03 常见的化学仪器-2021年中考化学考点一遍过.pdf
- 考点03 一次方程(组)与其应用-2022年中考数学一轮复习(浙江专用)(解析版).pdf
- 考点04:句子含义理解(讲解)-2023年中考语文记叙文阅读重难点技巧提升(学生版).pdf
- 考点06知识梳理之诗句作用(练习)-2023年中考语文古诗词考点精讲精练(全国通用)解析版.pdf
- 考点08 动词和动词短语-2021年中考英语考点一遍过 (解析版).pdf
- 考点08 一次函数的图象和性质-2022年中考数学一轮复习(浙江专用)(解析版).pdf
- 考点08位置与函数-2022年中考数学与题型全归纳(全国通用)(原卷版).pdf
- 考点09 一次函数-2019年中考数学考点一遍过(浙江专版).pdf
- 考点10 反比例函数及其应用(解析版)-中考数学备考复习重点资料归纳汇总.pdf
- 考点11 二次函数-2019年中考数学考点一遍过(浙江专版).pdf
文档评论(0)