Hogwarts正式开学以后,Harry发现在Hogwarts里,某些楼梯并不是静止不动的,相反,他们每隔一分钟就变动一次方向. 
比如下面的例子里,一开始楼梯在竖直方向,一分钟以后它移动到了水平方向,再过一分钟它又回到了竖直方向.Harry发现对他来说很难找到能使得他最快到达目的地的路线,这时Ron(Harry最好的朋友)告诉Harry正好有一个魔法道具可以帮助他寻找这样的路线,而那个魔法道具上的咒语,正是由你纂写的. 

Input测试数据有多组,每组的表述如下: 
第一行有两个数,M和N,接下来是一个M行N列的地图,'*'表示障碍物,'.'表示走廊,'|'或者'-'表示一个楼梯,并且标明了它在一开始时所处的位置:'|'表示的楼梯在最开始是竖直方向,'-'表示的楼梯在一开始是水平方向.地图中还有一个'S'是起点,'T'是目标,0<=M,N<=20,地图中不会出现两个相连的梯子.Harry每秒只能停留在'.'或'S'和'T'所标记的格子内. 
Output只有一行,包含一个数T,表示到达目标的最短时间. 
注意:Harry只能每次走到相邻的格子而不能斜走,每移动一次恰好为一分钟,并且Harry登上楼梯并经过楼梯到达对面的整个过程只需要一分钟,Harry从来不在楼梯上停留.并且每次楼梯都恰好在Harry移动完毕以后才改变方向. 
Sample Input

5 5
**..T
**.*.
..|..
.*.*.
S....

Sample Output

7
思路:BFS,比较坑的地方就是如果过桥后不标记之前已经走过了,它又会走一遍。
AC Code:
#include<iostream>
#include<cstring>
#include<queue>
#include<utility>
#include<cstdio>
using namespace std;
typedef pair<int,int> P;
int N,M,sx,sy,gx,gy;
char maze[][];
int vis[][];
int dx[]={,,-,},dy[]={,,,-};
int INF=0x3f3f3f3f;
int bfs(){
queue<P> q;
P p;
q.push(P(sx,sy));
vis[sx][sy]=;
while(!q.empty() ){
p=q.front() ;
q.pop() ;
if(p.first ==gx&&p.second==gy) break;
for(int i=;i<;i++){
int nx=p.first +dx[i],ny=p.second +dy[i];
if(nx>=&&nx<N&&ny>=&&ny<M&&maze[nx][ny]!='*'&&vis[nx][ny]==INF){
if(maze[nx][ny]=='.'||maze[nx][ny]=='T'){
vis[nx][ny]=vis[p.first ][p.second ]+;
q.push(P(nx,ny));
}
else if(maze[nx][ny]=='|'){
if(vis[p.first ][p.second]%){
//奇数对于同向不能通过 ,异向可行
if(!dy[i]&&maze[nx+dx[i]][ny]!='#'&&vis[nx+dx[i]][ny]==INF){//同向 dx=0
vis[p.first][p.second]++;
q.push(P(p.first ,p.second ));
}
else if(!dx[i]&&maze[nx][ny+dy[i]]!='#'&&vis[nx][ny+dy[i]]==INF){//异向 dy=0
// vis[nx][ny]=-1;
nx+=dx[i];
ny+=dy[i];
vis[nx][ny]=vis[p.first ][p.second]+;
q.push(P(nx,ny));
}
}
else{
if(!dx[i]&&maze[nx][ny+dy[i]]!='#'&&vis[nx][ny+dy[i]]==INF){//异向
vis[p.first][p.second]++;
q.push(P(p.first ,p.second ));
}
else if(!dy[i]&&maze[nx+dx[i]][ny]!='#'&&vis[nx+dx[i]][ny]==INF){//同向
// vis[nx][ny]=-1;
nx+=dx[i];
ny+=dy[i];
vis[nx][ny]=vis[p.first ][p.second]+;
q.push(P(nx,ny));
}
}
}
else if(maze[nx][ny]=='-'){
if(vis[p.first ][p.second]%){
//奇数对于同向不能通过 ,异向可行
if(!dx[i]&&maze[nx][ny+dy[i]]!='#'&&vis[nx][ny+dy[i]]==INF){//同向 dy=0
vis[p.first][p.second]++;
q.push(P(p.first ,p.second ));
}
else if(!dy[i]&&maze[nx+dx[i]][ny]!='#'&&vis[nx+dx[i]][ny]==INF){//异向 dx=0
// vis[nx][ny]=-1;
nx+=dx[i];
ny+=dy[i];
vis[nx][ny]=vis[p.first ][p.second]+;
q.push(P(nx,ny));
}
}
else{
if(!dy[i]&&maze[nx+dx[i]][ny]!='#'&&vis[nx+dx[i]][ny]==INF){//异向
vis[p.first][p.second]++;
q.push(P(p.first ,p.second ));
}
else if(!dx[i]&&maze[nx][ny+dy[i]]!='#'&&vis[nx][ny+dy[i]]==INF){//同向
// vis[nx][ny]=-1;
nx+=dx[i];
ny+=dy[i];
vis[nx][ny]=vis[p.first ][p.second]+;
q.push(P(nx,ny));
}
}
}
}
}
}
return vis[gx][gy];
}
int main(){
while(~scanf("%d%d",&N,&M)){
getchar();
for(int i=;i<N;i++){
for(int j=;j<M;j++){
scanf("%c",&maze[i][j]);
if(maze[i][j]=='S') sx=i,sy=j;
if(maze[i][j]=='T') gx=i,gy=j;
}
getchar();
}
memset(vis,INF,sizeof(vis));
cout<<bfs()<<endl;
}
}

诡异的楼梯 HDU - 1180的更多相关文章

  1. M - 诡异的楼梯 HDU - 1180(BFS + 在某个点等待一下 / 重复走该点)

    M - 诡异的楼梯 HDU - 1180 Hogwarts正式开学以后,Harry发现在Hogwarts里,某些楼梯并不是静止不动的,相反,他们每隔一分钟就变动一次方向. 比如下面的例子里,一开始楼梯 ...

  2. HDU 1180 诡异的楼梯(超级经典的bfs之一,需多回顾)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1180 诡异的楼梯 Time Limit: 2000/1000 MS (Java/Others)     ...

  3. hdu 1180 诡异的楼梯

    诡异的楼梯 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)Total Subm ...

  4. hdu 1180 诡异的楼梯 (bfs)

    诡异的楼梯 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others) Total Sub ...

  5. HDU 1180 诡异的楼梯(BFS)

    诡异的楼梯 Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit Status ...

  6. hdu 1180诡异的楼梯(bfs)

    诡异的楼梯 Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 131072/65536K (Java/Other) Total Submis ...

  7. hdu 1180:诡异的楼梯(BFS广搜)

    诡异的楼梯 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)Total Subm ...

  8. HDU 1180 诡异的楼梯【BFS/楼梯随时间变化】

    诡异的楼梯 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) Total Submis ...

  9. 诡异的楼梯(bfs)hdu1180

    诡异的楼梯 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submiss ...

随机推荐

  1. fedora安装了phpmyadmin后, mariadb无法启动?

    参考:http://www.linuxidc.com/Linux/2015-10/123945.htm where, which, when,等不但可以用在从句中, 而且可以用在 动词不定式中, 如: ...

  2. 转方阵|2012年蓝桥杯B组题解析第五题-fishers

    (6')转方阵 对一个方阵转置,就是把原来的行号变列号,原来的列号变行号 例如,如下的方阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 转置后变为: 1 5 9 1 ...

  3. [蓝桥] 基础练习 十进制转十六进制 (java)

    问题描述 十六进制数是在程序设计时经常要使用到的一种整数的表示方式.它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15.十六进制的计数方法是满1 ...

  4. 【AI】微软人工智能学习笔记(一)

    数据分析平台 01|数据平台概况图示 上面图中所示就是微软人工智能数据平台的相关的技术. 02.1| Cortana Intelligence Suite 从上面图中可以看到, 其中有一个Cortan ...

  5. Docker之Swarm

    Docker学习笔记 — Swarm搭建Docker集群 Swarm在schedule节点运行容器的时候,会根据指定的策略来计算最适合运行容器的节点,目前支持的策略有:spread, binpack, ...

  6. CSS深入

    块元素:div.h1.p等等. 列表的样式: /*使用系统提供的一些样式:例如无序.有序都可以使用circle*/ ul{ list-style-type: circle; } ol{ list-st ...

  7. R工具包一网打尽

    这里有很多非常不错的R包和工具. 该想法来自于awesome-machine-learning. 这里是包的导航清单,看起来更方便 >>>导航清单 通过这些翻译了解这些工具包,以后干 ...

  8. _itemmod_gem_remove

    该表可配置以一定代价移除宝石,移除后获得该宝石 `entry`宝石ID `reqId` 需求ID `chance`几率 `comond` 备注

  9. python 协程 demo

    # -*- coding: UTF- -*- import gevent from gevent import socket from gevent import event rev=socket.s ...

  10. java扫描文件夹下面的所有文件(递归与非递归实现)

    java中扫描指定文件夹下面的所有文件扫描一个文件夹下面的所有文件,因为文件夹的层数没有限制可能多达几十层几百层,通常会采用两种方式来遍历指定文件夹下面的所有文件.递归方式非递归方式(采用队列或者栈实 ...