http://acm.hdu.edu.cn/showproblem.php?pid=1180

Problem Description
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

Hint

Hint

地图如下:

 题目解析:
一遍就A了,我也不知道注意什么。我写的有点长,但容易懂。
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <queue>
using namespace std;
char map[][];
int v[][];
int n,m;
struct node
{
int ans,x,y;
friend bool operator<(struct node a,struct node b)//按ans从小到大排序
{
return a.ans>b.ans;
}
};
struct node t,f;
void bfs(int xx,int yy)
{
memset(v,,sizeof(v));
priority_queue<node>q;
t.x=xx;
t.y=yy;
t.ans=;
q.push(t);
v[xx][yy]=;
while(!q.empty())
{
t=q.top();
q.pop();
if(map[t.x][t.y]=='T')
{
printf("%d\n",t.ans);
return ;
}
for(int i=; i<; i++)
{
if(i==)
{
f.x=t.x+;
f.y=t.y+;
if(f.x>=&&f.x<n&&f.y>=&&f.y<m&&v[f.x][f.y]==&&map[f.x][f.y]!='*')
{
if(map[f.x][f.y]=='.'||map[f.x][f.y]=='T')
{
f.ans=t.ans+;
v[f.x][f.y]=;
q.push(f);
}
else if(map[f.x][f.y]=='|')
{
if(t.ans%==&&map[f.x+][f.y]!='*'&&v[f.x+][f.y]==)
{
f.ans=t.ans+;
f.x=f.x+;
q.push(f);
v[f.x][f.y]=;
}
else if(t.ans%==&&map[f.x+][f.y]!='*'&&v[f.x+][f.y]==)
{
f.ans=t.ans+;
f.x=f.x+;
q.push(f);
v[f.x][f.y]=;
}
}
else if(map[f.x][f.y]=='-')
{
if(t.ans%==&&map[f.x+][f.y]!='*'&&v[f.x+][f.y]==)
{
f.ans=t.ans+;
f.x=f.x+;
q.push(f);
v[f.x][f.y]=;
}
else if(t.ans%==&&map[f.x+][f.y]!='*'&&v[f.x+][f.y]==)
{
f.ans=t.ans+;
f.x=f.x+;
q.push(f);
v[f.x][f.y]=;
}
}
}
}
else if(i==)
{
f.x=t.x-;
f.y=t.y+;
if(f.x>=&&f.x<n&&f.y>=&&f.y<m&&v[f.x][f.y]==&&map[f.x][f.y]!='*')
{
if(map[f.x][f.y]=='.'||map[f.x][f.y]=='T')
{
f.ans=t.ans+;
v[f.x][f.y]=;
q.push(f);
}
else if(map[f.x][f.y]=='|')
{
if(t.ans%==&&map[f.x-][f.y]!='*'&&v[f.x-][f.y]==)
{
f.ans=t.ans+;
f.x=f.x-;
q.push(f);
v[f.x][f.y]=;
}
else if(t.ans%==&&map[f.x-][f.y]!='*'&&v[f.x-][f.y]==)
{
f.ans=t.ans+;
f.x=f.x-;
q.push(f);
v[f.x][f.y]=;
}
}
else if(map[f.x][f.y]=='-')
{
if(t.ans%==&&map[f.x-][f.y]!='*'&&v[f.x-][f.y]==)
{
f.ans=t.ans+;
f.x=f.x-;
q.push(f);
v[f.x][f.y]=;
}
else if(t.ans%==&&map[f.x-][f.y]!='*'&&v[f.x-][f.y]==)
{
f.ans=t.ans+;
f.x=f.x-;
q.push(f);
v[f.x][f.y]=;
}
}
}
}
else if(i==)
{
f.x=t.x+;
f.y=t.y+;
if(f.x>=&&f.x<n&&f.y>=&&f.y<m&&v[f.x][f.y]==&&map[f.x][f.y]!='*')
{
if(map[f.x][f.y]=='.'||map[f.x][f.y]=='T')
{
f.ans=t.ans+;
v[f.x][f.y]=;
q.push(f);
}
else if(map[f.x][f.y]=='-')
{
if(t.ans%==&&map[f.x][f.y+]!='*'&&v[f.x][f.y+]==)
{
f.ans=t.ans+;
f.y=f.y+;
q.push(f);
v[f.x][f.y]=;
}
else if(t.ans%==&&map[f.x][f.y+]!='*'&&v[f.x][f.y+]==)
{
f.ans=t.ans+;
f.y=f.y+;
q.push(f);
v[f.x][f.y]=;
}
}
else if(map[f.x][f.y]=='|')
{
if(t.ans%==&&map[f.x][f.y+]!='*'&&v[f.x][f.y+]==)
{
f.ans=t.ans+;
f.y=f.y+;
q.push(f);
v[f.x][f.y]=;
}
else if(t.ans%==&&map[f.x][f.y+]!='*'&&v[f.x][f.y+]==)
{
f.ans=t.ans+;
f.y=f.y+;
q.push(f);
v[f.x][f.y]=;
}
}
}
}
else if(i==)
{
f.x=t.x+;
f.y=t.y-;
if(f.x>=&&f.x<n&&f.y>=&&f.y<m&&v[f.x][f.y]==&&map[f.x][f.y]!='*')
{
if(map[f.x][f.y]=='.'||map[f.x][f.y]=='T')
{
f.ans=t.ans+;
v[f.x][f.y]=;
q.push(f);
}
else if(map[f.x][f.y]=='-')
{
if(t.ans%==&&map[f.x][f.y-]!='*'&&v[f.x][f.y-]==)
{
f.ans=t.ans+;
f.y=f.y-;
q.push(f);
v[f.x][f.y]=;
}
else if(t.ans%==&&map[f.x][f.y-]!='*'&&v[f.x][f.y-]==)
{
f.ans=t.ans+;
f.y=f.y-;
q.push(f);
v[f.x][f.y]=;
}
}
else if(map[f.x][f.y]=='|')
{
if(t.ans%==&&map[f.x][f.y-]!='*'&&v[f.x][f.y-]==)
{
f.ans=t.ans+;
f.y=f.y-;
q.push(f);
v[f.x][f.y]=;
}
else if(t.ans%==&&map[f.x][f.y-]!='*'&&v[f.x][f.y-]==)
{
f.ans=t.ans+;
f.y=f.y-;
q.push(f);
v[f.x][f.y]=;
}
}
}
} }
}
return ;
}
int main()
{
int j;
while(scanf("%d%d",&n,&m)!=EOF)
{
for(int i=; i<n; i++)
{
scanf("%*c%s",map[i]);
}
for(int i=; i<n; i++)
{
for(j=; j<m; j++)
{
if(map[i][j]=='S')
{
bfs(i,j);
break;
}
}
if(j!=m) break;
}
}
return ;
}

HDU1180:诡异的楼梯(bfs+优先队列)的更多相关文章

  1. hdu1180 诡异的楼梯 bfs

    题目链接:http://icpc.njust.edu.cn/Problem/Hdu/1180/ 题目和不同的bfs有个不同的地方就是存在横着的或者竖着的楼梯,楼梯每过一个时刻就改变一次横竖的走向,人可 ...

  2. hdu - 1180 诡异的楼梯 (bfs+优先队列)

    http://acm.hdu.edu.cn/showproblem.php?pid=1180 注意点就是楼梯是在harry移动完之后才会改变方向,那么只要统计到达这个点时间奇偶性,就可以知道当前楼梯是 ...

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

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

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

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

  5. hdu 1180 诡异的楼梯(优先队列)

    Hogwarts正式开学以后,Harry发现在Hogwarts里,某些楼梯并不是静止不动的,相反,他们每隔一分钟就变动一次方向.  比如下面的例子里,一开始楼梯在竖直方向,一分钟以后它移动到了水平方向 ...

  6. HDU1180:诡异的楼梯

    传送门 题意 迷宫搜索 分析 这题写起来挺简单的,锻炼搜索基本功,一开始用记忆化搜索TLE了,改用访问标记,0ms过了,用优先队列保证终点最快达到,我会在代码中提供一些强力数据 trick 1.遇到梯 ...

  7. hdu1180奇怪的楼梯……bfs迷阵……wa该16二级,我太渣滓

    #include<iostream> #include<queue> #include<cstring> using namespace std; int row, ...

  8. 诡异的楼梯(bfs)hdu1180

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

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

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

随机推荐

  1. 《转》Python学习(18)-python函数(二)

    转自 http://www.cnblogs.com/BeginMan/p/3173328.html 一.装饰器(decorators) 装饰器的语法以@开头,接着是装饰器函数的名字.可选参数. 紧跟装 ...

  2. kubernetes 测试 Mariadb gtid 主从复制.

    k8s 为 1个master 3个node 下载镜像 : mariadb 镜像版本是10.2.13 (此时10.3还没发布正式版) docker pull mariadb push到私有仓库 dock ...

  3. 高效使用github

    下面两个资料是我在github上面整理出来的repo,不断进行更新,将遇到的有帮助的文章尽量整理到上面,方便初学者也方便回顾学习.如果恰好你也有一些资料文章,欢迎fork - modify - pul ...

  4. 【大数据系列】windows环境下搭建hadoop开发环境使用api进行基本操作

    前言 搭建完hadoop集群之后在windows环境下搭建java项目进行测试 操作hdfs中的文件 版本一 package com.slp.hadoop274.hdfs; import java.i ...

  5. 【linux系列】cenos7安装jdk

    一.下载jdk,我采用的jdk.tar.gz的安装包 二.创建jdk安装目录 三.安装包解压 四.jdk环境变量配置 五.使配置的环境变量生效 六.检查jdk是否安装成功

  6. sonarqube插件开发(二) 开发插件

    一.环境准备 java 1.8, maven 3.1 检查自己的环境是否支持 sonarqube的插件开发 java -version mvn -version 二.创建maven项目 pom.xml ...

  7. 利用开源架构ELK构建分布式日志系统

    问题导读 1.ELK产生的背景?2.ELK的基本组成模块以及各个模块的作用?3.ELK的使用总计有哪些? 背景 日志,对每个系统来说,都是很重要,又很容易被忽视的部分.日志里记录了程序执行的关键信息, ...

  8. Bitbucket - 用git 用法

    核心流程: 从远端中心repo那里Git clone 到本地,再在本地开发(add, commit), 通常会利用branch管理,如果觉得code 没问题了,就push到远端的中心repo上.这里中 ...

  9. webconfig的配置说明

    转自 :http://www.cnblogs.com/kissdodog/archive/2013/04/16/3025315.html <?xml version="1.0" ...

  10. 对Yii2中 yii\web\User的理解,和自建的app\models\User(基础版),frontend\models\User的应用原理

    yii\web\User 是一个统称,为用户,没有具体实例,只能管理: 此处以app\models\User为基准: app\models\User 是映射数据表user的model类,同时也实现接口 ...