(BFS)1097: Yuchang and Zixiang ‘s maze
#include<bits/stdc++.h>
using namespace std; const int maxn = ;
char maze[maxn][maxn]; //存储迷宫
int vis[maxn][maxn]; //存储是否访问过标记
int step[maxn][maxn]; //存储步数 int n, m; //m,n分别是迷宫的大小,在check中判断越界要使用,需要声明为全局变量 int Move[][] = {, , -, , , , , -}; //四个方向可走,使用for循环来对当前坐标进行上下左右移动 struct point //结构体存储x,y的坐标,结构体的对象放在队列中
{
int x, y;
} in, out, beg; int check(int x, int y)
{
if(vis[x][y] == && x >= && x <= n && y >= && y <= m && maze[x][y] != '#')
return ;
else
return ;
} int bfs()
{
memset(vis, , sizeof(vis)); //初始所有坐标的访问设置为0
memset(step, , sizeof(step)); //初始所有步数为0 vis[beg.x][beg.y] = ; //beg坐标点开始标记为1,表示已经访问
step[beg.x][beg.y] = ; //beg所在的坐标为第一个,步数为0 queue<point>q; q.push(beg); //开始的那个点进队 while(!q.empty())
{
out = q.front(); //out记住队头元素
q.pop();
for(int i = ; i < ; i++)
{
in.x = out.x + Move[i][]; //循环四次,in分别是队头元素的上、下、左、右邻接坐标点
in.y = out.y + Move[i][];
if(check(in.x, in.y)) //对in作是否访问过、越界、是否是障碍检查
{
if(maze[in.x][in.y] == 'E') //判断in是否是到达的坐标
{
return step[out.x][out.y] + ; //若到达,返回in前一个坐标的步数+1
}
q.push(in); //不是终点,继续将in进队
vis[in.x][in.y] = ;
step[in.x][in.y] = step[out.x][out.y] + ; // 将in的步数在它前一个坐标的步数+1
}
}
}
return -;
} int main()
{
while(~scanf("%d%d", &n, &m))
{
for(int i = ; i <= n; i++)
{
for(int j = ; j <= m; j++)
{
maze[i][j] = '.';
}
}
int t;
scanf("%d", &t);
while(t--)
{
int x, y;
scanf("%d%d", &x, &y);
maze[x][y] = '#'; //将障碍的坐标设置为#
}
int a, b, c, d;
scanf("%d%d%d%d", &a, &b, &c, &d);
if(a == c && b == d) //判断如果出发点和终点坐标一样,就直接输出0
{
printf("0\n");
}
else //否则进行广度搜索
{
maze[a][b] = 'S';
maze[c][d] = 'E';
for(int i = ; i <= n; i++)
{
for(int j = ; j <= m; j++)
{
if(maze[i][j] == 'S') // 找到起始点,将起始点的坐标存入结构体变量beg中
{
beg.x = i;
beg.y = j;
}
}
}
int ans = bfs();
printf("%d\n", ans);
}
}
return ;
}
(BFS)1097: Yuchang and Zixiang ‘s maze的更多相关文章
- 深搜(DFS)广搜(BFS)详解
图的深搜与广搜 一.介绍: p { margin-bottom: 0.25cm; direction: ltr; line-height: 120%; text-align: justify; orp ...
- 【算法导论】图的广度优先搜索遍历(BFS)
图的存储方法:邻接矩阵.邻接表 例如:有一个图如下所示(该图也作为程序的实例): 则上图用邻接矩阵可以表示为: 用邻接表可以表示如下: 邻接矩阵可以很容易的用二维数组表示,下面主要看看怎样构成邻接表: ...
- 深度优先搜索(DFS)与广度优先搜索(BFS)的Java实现
1.基础部分 在图中实现最基本的操作之一就是搜索从一个指定顶点可以到达哪些顶点,比如从武汉出发的高铁可以到达哪些城市,一些城市可以直达,一些城市不能直达.现在有一份全国高铁模拟图,要从某个城市(顶点) ...
- 【BZOJ5492】[HNOI2019]校园旅行(bfs)
[HNOI2019]校园旅行(bfs) 题面 洛谷 题解 首先考虑暴力做法怎么做. 把所有可行的二元组全部丢进队列里,每次两个点分别向两侧拓展一个同色点,然后更新可行的情况. 这样子的复杂度是\(O( ...
- 深度优先搜索(DFS)和广度优先搜索(BFS)
深度优先搜索(DFS) 广度优先搜索(BFS) 1.介绍 广度优先搜索(BFS)是图的另一种遍历方式,与DFS相对,是以广度优先进行搜索.简言之就是先访问图的顶点,然后广度优先访问其邻接点,然后再依次 ...
- 图的 储存 深度优先(DFS)广度优先(BFS)遍历
图遍历的概念: 从图中某顶点出发访遍图中每个顶点,且每个顶点仅访问一次,此过程称为图的遍历(Traversing Graph).图的遍历算法是求解图的连通性问题.拓扑排序和求关键路径等算法的基础.图的 ...
- 数据结构与算法之PHP用邻接表、邻接矩阵实现图的广度优先遍历(BFS)
一.基本思想 1)从图中的某个顶点V出发访问并记录: 2)依次访问V的所有邻接顶点: 3)分别从这些邻接点出发,依次访问它们的未被访问过的邻接点,直到图中所有已被访问过的顶点的邻接点都被访问到. 4) ...
- 层层递进——宽度优先搜索(BFS)
问题引入 我们接着上次“解救小哈”的问题继续探索,不过这次是用宽度优先搜索(BFS). 注:问题来源可以点击这里 http://www.cnblogs.com/OctoptusLian/p/74296 ...
- HDU.2612 Find a way (BFS)
HDU.2612 Find a way (BFS) 题意分析 圣诞节要到了,坤神和瑞瑞这对基佬想一起去召唤师大峡谷开开车.百度地图一下,发现周围的召唤师大峡谷还不少,这对基佬纠结着,该去哪一个...坤 ...
随机推荐
- Jmeter-第三方插件安装
1.插件下载 官方地址https://jmeter-plugins.org/install/Install/ 网盘地址链接: https://pan.baidu.com/s/1E4lnMWDGPWCN ...
- js 获取项目名称
//获取项目名称function getWebName(){ var pathName = window.location.pathname.substring(1); var webName = p ...
- postgresql + omniDB
docker:组装 使用Postgres数据库的web应用 登录到psql的方法: psql --host=localhost --dbname=database-name --username=po ...
- eclipse中tomcat正常启动,但浏览器访问不了tomcat首页之tomcat配置问题
症状: tomcat在eclipse里面能正常启动,而在浏览器中访问http://localhost:8080/不能访问,且报404错误.同时其他项目页面也不能访问. 关闭eclipse里面的tomc ...
- javascript闭包的理解和实例
所谓闭包,值得是词法表示包括不必要计算的变量的函数,也就是说,该函数可以使用函数外定义的变量. 顺便提示一下: 词法作用域:变量的作用域是在定义时决定而不是执行时决定,也就是说词法作用域取决于源码,通 ...
- AtCoder Beginner Contest 153 题解
目录 AtCoder Beginner Contest 153 题解 A - Serval vs Monster 题意 做法 程序 B - Common Raccoon vs Monster 题意 做 ...
- VB断点拷贝大文件(WIN7系统需要更改某个API函数,具体我也忘了)
小弟以前租碟在电脑上看VCD,有时候拷贝经典的影片到硬盘上可惜碰到比较粗糙的碟子就很难拷贝过去,因此编了个断点拷贝文件的程序.本程序用于拷贝大文件,并可在旧文件上接着拷贝本程序能在无法读取数据的情况下 ...
- xshell连接本地虚拟机中的centos
1. 一开始Xshell连接不上(设置为DHCP 动态IP)虚拟机上的centos8 参考这篇博文,将centos上的DHCP改为static 静态IP xshell连接本地虚拟机中的centos 2 ...
- 实例:通过调用外部程序进行录制视频(ffmpeg.exe)
相关知识点: 1. ffmpeg可以用下面的参数来录制Windows 桌面操作的视频. ffmpeg.exe -y -rtbufsize 100M -f gdigrab -framerate 10 - ...
- mysql数据库-笔记
基本概念篇 SQL语言的分类(DDL.DML.DCL.DQL) 对应的英文全程:data (definition.manipulation.control.query)language 参考资料: h ...