codeforces #Round354-div2-D(BFS)
题目链接:题目链接
题意:一个n*m的区域,每个格子都有上下左右四个门,相邻的两个格子A可以通向B当且仅当A对B的门和B对A的门都打开,问从起点S到终点T需要的最短时间
#include<bits/stdc++.h>
using namespace std;
const int N=1003;
int n,m;
int sx,sy,tx,ty;
int dirx[]={1,-1,0,0};
int diry[]={0,0,1,-1};
char matrix[N][N];
bool visit[N][N][4];
char rotat[6][15]={{"+-|^><vLRUD*"},{"+|->v^<UDRL*"},{"+-|v<>^RLDU*"},{"+|-<^v>DULR*"}};
class node
{
public:
int x;
int y;
int angle;
int step;
public:
node(int x,int y,int a,int s):x(x),y(y),angle(a),step(s){}
};
int number(char c)
{
if(c=='+') return 0;
if(c=='-') return 1;
if(c=='|') return 2;
if(c=='^') return 3;
if(c=='>') return 4;
if(c=='<') return 5;
if(c=='v') return 6;
if(c=='L') return 7;
if(c=='R') return 8;
if(c=='U') return 9;
if(c=='D') return 10;
if(c=='*') return 11;
}
bool yestop(char c)
{
if(c=='+'||c=='|'||c=='^'||c=='L'||c=='R'||c=='D')
return 1;
return 0;
}
bool yesbottom(char c)
{
if(c=='+'||c=='|'||c=='v'||c=='L'||c=='R'||c=='U')
return 1;
return 0;
}
bool yesleft(char c)
{
if(c=='+'||c=='-'||c=='<'||c=='R'||c=='U'||c=='D')
return 1;
return 0;
}
bool yesright(char c)
{
if(c=='+'||c=='-'||c=='>'||c=='L'||c=='U'||c=='D')
return 1;
return 0;
}
bool in(int x,int y)
{
if(x<=0||x>n||y<=0||y>m)
return 0;
return 1;
}
queue<node> Q;
int bfs()
{
Q.push(node(sx,sy,0,0));
visit[sx][sy][0]=1;
while(!Q.empty())
{
node p=Q.front();
Q.pop();
if(p.x==tx&&p.y==ty)
return p.step;
for(int i=0;i<4;i++)
{
int nx=p.x+dirx[i];
int ny=p.y+diry[i];
switch(i)
{
case 0:
if(in(nx,ny)&&!visit[nx][ny][p.angle]&&yesbottom(rotat[p.angle][number(matrix[p.x][p.y])])
&&yestop(rotat[p.angle][number(matrix[nx][ny])]))
{
Q.push(node(nx,ny,p.angle,p.step+1));
visit[nx][ny][p.angle]=1;
}
break;
case 1:
if(in(nx,ny)&&!visit[nx][ny][p.angle]&&yestop(rotat[p.angle][number(matrix[p.x][p.y])])
&&yesbottom(rotat[p.angle][number(matrix[nx][ny])]))
{
Q.push(node(nx,ny,p.angle,p.step+1));
visit[nx][ny][p.angle]=1;
}
break;
case 2:
if(in(nx,ny)&&!visit[nx][ny][p.angle]&&yesright(rotat[p.angle][number(matrix[p.x][p.y])])
&&yesleft(rotat[p.angle][number(matrix[nx][ny])]))
{
Q.push(node(nx,ny,p.angle,p.step+1));
visit[nx][ny][p.angle]=1;
}
break;
case 3:
if(in(nx,ny)&&!visit[nx][ny][p.angle]&&yesleft(rotat[p.angle][number(matrix[p.x][p.y])])
&&yesright(rotat[p.angle][number(matrix[nx][ny])]))
{
Q.push(node(nx,ny,p.angle,p.step+1));
visit[nx][ny][p.angle]=1;
}
break;
}
}
p.angle=(p.angle+1)%4;
if(!visit[p.x][p.y][p.angle])
{
p.step++;
Q.push(node(p));
visit[p.x][p.y][p.angle]=1;
}
}
return -1;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
scanf("%s",matrix[i]+1);
scanf("%d%d",&sx,&sy);
scanf("%d%d",&tx,&ty);
printf("%d\n",bfs());
}
codeforces #Round354-div2-D(BFS)的更多相关文章
- CodeForces 540C Ice Cave (BFS)
http://codeforces.com/problemset/problem/540/C Ice Cave Time Limit:2000MS Memory Limit:262 ...
- Codeforces #536 div2 E (1106E)Lunar New Year and Red Envelopes (DP)
题意:过年了,Bob要抢红包.抢红包的时间段为1 - n,有m个红包,每个红包有三个属性:st(红包出现的时间), ed(红包消失的时间),d(如果抢了这个红包,能够抢下一个红包的时间),w(红包的收 ...
- codeforces 1283D. Christmas Trees(bfs)
链接: https://codeforces.com/contest/1283/problem/D 题意:给定n个不同的整数点,让你找m个不同的整数点,使得这m个点到到这n个点最小距离之和最小. 思路 ...
- 深搜(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) ...
随机推荐
- hdu----(1599)最大子矩阵(几何/dp)
最大子矩阵 Time Limit: 30000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...
- oracle知识点
创建序列 create sequence a_seq --创建序列名字为 a_seqminvalue 1 -- 最小值为 1maxvalue 99999 --- 最大值为 99999 start wi ...
- poi 读取 excel(.xlsx) 2007及以上版本
1.注意的一点是sh.getLastRowNum(),比实际的行数少一行 涉及到的包:
- Tomcat编码问题
在Tomcat7中,默认URIEncoding="iso8859-1",get请求由于url会完全出现在地址栏,所以传递中文到后台会乱码,需要改成URIEncoding=" ...
- 转:PHP Composer 管理工具的介绍 这个相对清晰点
转自:http://www.aichengxu.com/view/14872 一.PHP的一些臭历史 Dependency Manager For PHP,Composer.在Composer还没诞生 ...
- MyEclipse生成WAR包并在Tomcat下部署发布[转]
从来没有想过web项目还能打包的,但是有要求,就不得不去实现,在网上找了一下,发现挺简单的. 首先是使用MyEclipse将web项目打包,如下图所示. 右键选中项目,选择export. 然后选择 ...
- li排序的两种方法
1.一般做法 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <ti ...
- kindeditor 操作时同步到textarea
KindEditor.ready(function(K) { editor1 = K.create('textarea[name="sponsor"]', { resizeType ...
- 关于python中的编码:unicode, utf-8, gb2312
计算机早期是只支持ASCII码的,经过long long的发展,出现了这些支持世界上各种语言字符的编码:unicode, utf-8, gb2312. 对于unicode, utf-8, gb2312 ...
- 滑雪(dp好题)
题目描述:贝西去科罗拉多州去滑雪,不过还她不太会玩,只是个能力为 1 的渣渣.贝西从 0 时刻进入滑雪场,一到 T 时刻就必须离开.滑雪场里有 N 条斜坡,第 i 条斜坡滑行一次需要 Di 分钟,要求 ...