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) ...
随机推荐
- 201. Bitwise AND of Numbers Range -- 连续整数按位与的和
Given a range [m, n] where 0 <= m <= n <= 2147483647, return the bitwise AND of all numbers ...
- inout
在函数声明时就用inout代替var 这样以后可以在函数内部修改外面的值 类似于C语言的传入指针 func change (inout num:Int) { num = 10 } var a = 2 ...
- 分支语句switch case
Switch case必须与break一起使用 Break 是跳转语句.与switch case连用的时候是跳出最近的{}. static void Main(string[]args ) { //s ...
- BZOJ3206 [Apio2013]道路费用
首先我们强制要求几条待定价的边在MST中,建出MST 我们发现这个MST中原来的边是一定要被选上的,所以可以把点缩起来,搞成一棵只有$K$个点的树 然后$2^K$枚举每条边在不在最终的MST中,让在最 ...
- 和小猪一起搞微信公众号开发—获取Access_token
前言 前一篇小猪和大家分享了如何回复用户的简单文本,这一篇我们来看看如何获取Access_token 介绍 在前一篇中,我们实现了这么一个简单的过程:用户发送一个文本到公众号后,公众号在该文本后面加上 ...
- php的两个符号@和&---php总会要知道的系列
在写代码的时候,碰到了在函数和变量前家 @和$的的问题,于是就借这个机会,学习下php的传值和传引用这两种方式 首先 @ 运算符只对表达式有效.对新手来说一个简单的规则就是:如果能从某处得到值,就能在 ...
- nginx 配置优化的几个参数
nginx 配置优化的几个参数 2011-04-22 本文地址: http://blog.phpbean.com/a.cn/7/ --水平有限欢迎指正-- -- 最近在服务器上搞了一些nginx 研究 ...
- 哈希(Hask)
编辑 Hash,一般翻译做“散列”,也有直接音译为“哈希”的,就是把任意长度的输入(又叫做预映射, pre-image),通过散列算法,变换成固定长度的输出,该输出就是散列值.这种转换是一种压缩映射 ...
- 百度上传android包:应用名解析失败!
manifest 里面<application增加android:label="@string/app_name"
- UVa 10253 - Series-Parallel Networks
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...