




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
宽度优先搜索算法1.概述:宽度优先搜索算法(又称广度优先搜索)是最简便的图的搜索算法之一,这一算法也是很多重要的图的算法的原型。Dijkstra单源最短路径算法和Prim最小生成树算法都采用了和宽度优先搜索类似的思想。其别名又叫BFS,属于一种盲目搜寻法,目的是系统地展开并检查图中的所有节点,以找寻结果。换句话说,它并不考虑结果的可能位置,彻底地搜索整张图,直到找到结果为止。之所以称之为宽度优先算法,是因为算法自始至终一直通过已找到和未找到顶点之间的边界向外扩展,就是说,算法首先搜索和s距离为k的所有顶点,然后再去搜索和S距离为k+l的其他顶点。例题hdu 1242/showproblem.php?pid=1242/zhuihunmiling/article/details/8979570(DFS做法)这一此我们介绍广度优先搜索按照惯例,我们还是先说一下该题目的主要易错点1.天使可能有多个朋友,所以不能从朋友的位置开始着天使,只能是从天使找离他最近的朋友2.题目要求的是找到一个用时最少的朋友,而不是步数最少既然是广度优先,那么必然用到队列,但是队列只能是先进先出,即是步数少的先遍历到,显然是不符合题目要求的,那应该怎么办呢?c+给我们提供了标准的函数库,可以引入#include 并定义优先队列类型 priority_queue,并自动对里面的元素进行排序如果排序不符合要求,可以给出小于号 “” 的运算符重载函数,当然在结构体里面进行了,代码里面有具体的实现广度优先搜索依然是简单的 出队-判断-扫描-入队 的四部曲。结构简单,程序也容易实现,现直接给出代码实现cpp view plaincopy1 #include 2 #include 3 #include 4 #include 5 #define N 201 6 using namespace std; 7 8 /优先队列解决,广度优先 9 struct Persion 10 11 int x,y; 12 int time; 13 friend bool operator b.time; / 返回队列中较小的元素; 则返回队列中较大的元素 16 17 18 ; 19 20 int dir42=-1,0,1,0,0,-1,0,1; 21 char mapNN; 22 int visitedNN; 23 int m,n; 24 25 26 int BFS(int x,int y) 27 28 29 30 priority_queue q; 31 Persion current,next; 32 memset(visited,0,sizeof(visited); 33 34 current.x=x; 35 current.y=y; 36 current.time=0; 37 visitedcurrent.xcurrent.y=1; 38 q.push(current); 39 40 41 while(!q.empty() 42 43 44 current=q.top(); 45 q.pop(); 46 for(int i=0;i=0&next.x=0&next.ynm&(m|n) 85 86 87 for(i=0;in;i+) 88 for(j=0;jmapij; 92 if(mapij=a) 93 94 angle.x=i; 95 angle.y=j; 96 97 98 99 100 int time=BFS(angle.x,angle.y); 101 102 103 if(time=-1) 104 coutPoor ANGEL has to stay in the p
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 典当行股权债权转换与转让专项合同
- 水电站建设监理合同规范文本
- 智能制造企业股权合作分红及智能制造解决方案合同
- 污水处理厂污水泵站建设及设备租赁合同
- 智能交通枢纽土地使用权转让与交通管理合作代理合同
- 人类专业测试题及答案
- 电竞专业测试题及答案
- 学校机构工作总结
- 新媒体试用期转正工作总结
- 心病科副护士长工作汇报
- 2021年康平县工会系统招聘笔试试题及答案解析
- 一生一特长·一师一专长实施方案
- 游标卡尺的使用flash动画演示教学课件
- 汽车发动机电控系统实训工作页
- 矿山救援队伍训练大纲及考核要求
- 石油钻井用钻具培训讲义课件
- 管理层财务基础知识培训
- 整理词根词缀法初中英语学习
- 立式储罐重量表
- (高清版)建筑楼盖结构振动舒适度技术标准JGJ_T 441-2019
- 电气系统调试方案
评论
0/150
提交评论