再次迷宫救人——BFS
原创
上次用DFS解了迷宫救人:https://www.cnblogs.com/chiweiming/p/9313164.html
这次用BFS(广度优先搜索),实现广度优先搜索比深度优先搜索复杂,思路也复杂一些,但是不难理解。
深度优先搜索是一笔画下来,一条道走到黑;
广度优先搜索是多步同时进行,全面展开搜索;
两者都是在找到目的地前遍历所有路径,但是在寻找最短路径时,使用广度优先搜索一旦到达目的地,即
产生最短路径,而深度优先搜索需要比较所有能到达目的地的路径。
实现广度优先搜索用到了队列来存储目前已经搜查过的点,然后再在这些已经被搜查过的点的基础上再次搜索。
实现广度优先搜索的过程可以用下图来表示(按右、下、左、上的顺序来遍历):
起始点是1(入队列),1步之内可到达的点有2(入队列)和3(入队列),所以搜索2和3;
此时1已经无用,出队,2可以直达的点有4(入队)和5(入队),2无用出队;
3可直达的点有5(已遍历)和6(入队),3无用出队;
每遍历一个点判断是否为人质所在点,是则停止遍历。
Java:
import java.util.*; public class 迷宫救人 { static int n;
static int m; public static void main(String[] args) {
Scanner reader=new Scanner(System.in);
n=reader.nextInt();
m=reader.nextInt();
int flag=0; //0表示人质为找到
int head=0; //指向父结点
int tail=0; //指向尾结点
int maze[][]=new int[n][m]; //迷宫
int book[][]=new int[n][m]; //标志
int x[]=new int[n*m]; //队列横坐标
int y[]=new int[n*m]; //队列纵坐标
int step[]=new int[n*m]; //队列步数
int dir[][]= {
{0,1},{1,0},{0,-1},{-1,0} //右,下,左,上
};
for(int i=0;i<n;i++) {
for(int j=0;j<m;j++) {
maze[i][j]=reader.nextInt();
book[i][j]=0;
}
}
book[0][0]=1; //起始结点
//起始结点入队列
x[tail]=0;
y[tail]=0;
step[tail]=0;
tail++; //尾指针后移
while(head<=tail) {
for(int i=0;i<4;i++) {
int dx=x[head]+dir[i][0];
int dy=y[head]+dir[i][1];
if(dx<0 || dx>n-1 || dy<0 || dy>m-1) { //越界判断
continue;
}
if(maze[dx][dy]==1 || book[dx][dy]==1) { //障碍点和访问与否判断
continue;
}
//符合条件,入队列
book[dx][dy]=1;
x[tail]=dx;
y[tail]=dy;
step[tail]=step[head]+1;
tail++;
if(maze[dx][dy]==2) {
flag=1; //发现人质
break;
}
}
if(flag==1) {
break;
}
head++; //父结点出队
}
System.out.println("("+x[tail-1]+","+y[tail-1]+")"+" "+step[tail-1]);
} }
18:01:03
2018-07-19
再次迷宫救人——BFS的更多相关文章
- ZZULIOJ 1726 迷宫(BFS+小坑)
1726: 迷宫 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 394 Solved: 64 SubmitStatusWeb Board Descr ...
- 迷宫问题(bfs)
import java.util.LinkedList; import java.util.Queue; import java.util.Stack; public class BFS { priv ...
- HDU 1728 逃离迷宫(BFS)
Problem Description 给定一个m × n (m行, n列)的迷宫,迷宫中有两个位置,gloria想从迷宫的一个位置走到另外一个位置,当然迷宫中有些地方是空地,gloria可以穿越,有 ...
- HDU 1728:逃离迷宫(BFS)
http://acm.hdu.edu.cn/showproblem.php?pid=1728 逃离迷宫 Problem Description 给定一个m × n (m行, n列)的迷宫,迷宫中有 ...
- 迷宫问题(bfs的应用)
问题描述: 定义一个二维数组N*M(其中2<=N<=10;2<=M<=10),如5 × 5数组下所示: int maze[5][5] = { 0, 1, 0, 0, 0, 0, ...
- [Swust OJ 409]--小鼠迷宫问题(BFS+记忆化搜索)
题目链接:http://acm.swust.edu.cn/problem/409/ Time limit(ms): 1000 Memory limit(kb): 65535 Description ...
- HDU 1728 逃离迷宫(DFS||BFS)
逃离迷宫 Problem Description 给定一个m × n (m行, n列)的迷宫,迷宫中有两个位置,gloria想从迷宫的一个位置走到另外一个位置,当然迷宫中有些地方是空地,gloria可 ...
- 问题 1923: [蓝桥杯][算法提高VIP]学霸的迷宫 (BFS)
题目链接:https://www.dotcpp.com/oj/problem1923.html 题目描述 学霸抢走了大家的作业,班长为了帮同学们找回作业,决定去找学霸决斗.但学霸为了不要别人打扰,住在 ...
- POJ 3984 - 迷宫问题 - [BFS水题]
题目链接:http://poj.org/problem?id=3984 Description 定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, ...
随机推荐
- EasyWeChat微信开放平台第三方平台接入
EasyWeChat微信开放平台第三方平台接入 https://www.cnblogs.com/bainiu/p/8022729.html
- .net中webconfig自定义配置
在configuration节点,也就是文件的根节点下,增加如下节点 <appSettings> <!--<add key="propPath" value ...
- AppCan使用注意问题
1.文件上传的时候尽量使用uexUploadMsg,然后注意文件名,文件名一定要正确才能传上去.
- HBuilder使用技巧
ctrl+ Tab 切换 ctrl + shift + D 查找所写的函数
- 25 mysql怎么保证高可用
上一篇介绍了binlog的基本内容,在主备关系中,是每个备库接收主库的binlog并执行. 正常情况下,只要主库执行更新生成的所有的binlog,都可以传到备库并被正确执行,备库就能跟主库一致的状态, ...
- 参数传递中编码问题(Get/Post 方式)(一)
用JAVA在做一个支付接口时,需要和表现层的UTF8代码进行报文交换,因JAVA是GBK编码的,因此出现了小插曲.为此,花了点时间,重新梳理一下相关知识点. 以下内容是我转载的,觉得挺好的.... 一 ...
- python's twenty ninthday for me 模块和包
模块 和 脚本的 区别: 如果一个py文件被导入了,就是一个模块. 如果这个py文件被直接执行,这个被直接执行的文件就是一个脚本. 模块:1,没有具体的调用过程.2,能对外提供功能. pyc文件: ...
- mongodb基本操作和在springboot中的使用
本文介绍mongodb的使用 说明 起步 mongo通用类型 mongoshell的操作 CRUD操作 shell命令操作 索引操作 mongo在springboot中的使用 目录结构 依赖 prop ...
- 微信小程序API登录凭证(code),获得的用户登录态拥有一定的时效性
调用接口获取登录凭证(code)进而换取用户登录态信息,包括用户的唯一标识(openid) 及本次登录的 会话密钥(session_key).用户数据的加解密通讯需要依赖会话密钥完成. OBJECT参 ...
- Select/Poll/Epoll异步IO
IO多路复用 同步io和异步io,阻塞io和非阻塞io分别是什么,有什么样的区别? io模式 对于一次io 访问(以read为例),数据会先拷贝到操作系统内核的缓冲区,然后才会从操作系统内核的缓冲区拷 ...