- 0
- 0
- 约 8页
- 2024-05-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);//队列为空}
FutureX科学教育-创新课程像科学家一样思考像工程师一样解决问题
您可能关注的文档
最近下载
- 2022年四川德阳中考英语真题及答案.pdf VIP
- 湖北省武汉市2023年中考物理试卷((附参考答案)).pdf VIP
- 化工生产装置危险与可操作分析HAZOP分析报告.docx
- 2026年南阳科技职业学院单招职业适应性考试题库推荐.docx VIP
- SL∕T 618-2021 水利水电工程可行性研究报告编制规程.pdf
- 2026年南阳科技职业学院单招职业适应性考试题库推荐.docx VIP
- 2025年石灰吟题目及答案.doc VIP
- Unit1~8+期末基础知识达标(专项训练)-2025-2026学年译林版(三起)英语三年级上册.docx VIP
- 专监试题(土建考试版答案).docx VIP
- “十五五”规划建议61条要点速览PPT学习课件.pptx VIP
原创力文档

文档评论(0)