A计划

Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 30433    Accepted Submission(s): 7627

Problem Description
可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生命的考验。魔王已经发出消息说将在T时刻吃掉公主,因为他听信谣言说吃公主的肉也能长生不老。年迈的国王正是心急如焚,告招天下勇士来拯救公主。不过公主早已习以为常,她深信智勇的骑士LJ肯定能将她救出。
现据密探所报,公主被关在一个两层的迷宫里,迷宫的入口是S(0,0,0),公主的位置用P表示,时空传输机用#表示,墙用*表示,平地用.表示。骑士们一进入时空传输机就会被转到另一层的相对位置,但如果被转到的位置是墙的话,那骑士们就会被撞死。骑士们在一层中只能前后左右移动,每移动一格花1时刻。层间的移动只能通过时空传输机,且不需要任何时间。
 
Input
输入的第一行C表示共有C个测试数据,每个测试数据的前一行有三个整数N,M,T。 N,M迷宫的大小N*M(1 <= N,M <=10)。T如上所意。接下去的前N*M表示迷宫的第一层的布置情况,后N*M表示迷宫第二层的布置情况。
 
Output
如果骑士们能够在T时刻能找到公主就输出“YES”,否则输出“NO”。
 
Sample Input
1
5 5 14
S*#*.
.#...
.....
****.
...#.

..*.P
#.*..
***..
...*.
*.#..

 
Sample Output
YES
 
Source
 
Recommend
xhd
 
这道题有3个坑点:1、t时刻之前到公主那就行(一开始以为要在t时刻刚好到o(╥﹏╥)o)2、到达时光机‘#’时,若转移后也处于时光机位置,也是不行的(怎么可能让智勇的骑士来回传送是吧?)3、传送后到达公主的情况
 
刚开始,可以先对迷宫进行预处理,若一二层相同位置都是时光机、或一层是时光机另外一层是墙,将两层该位置全部堵死(赋值墙),然后就是简单的bfs求最短路了~
 
accode
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<sstream>
#include<cstring>
#include<string>
#include<vector>
#include<set>
#include<stack>
#include<queue>
#include<map>
#include<cmath>
#include<algorithm>
using namespace std;
#define inf 0x3f3f3f3f
#define ll long long
#define MAX_N 1000005
#define gcd(a,b) __gcd(a,b)
#define mem(a,x) memset(a,x,sizeof(a))
#define mid(a,b) a+b/2
#define stol(a) atoi(a.c_str())//string to long
int N,M,T;
int pn,px,py;
string maze[][];
int dirx[] = {-,,,};
int diry[] = {,,-,};
ll len[][][];
int vis[][][];
int nx,ny,nn;
struct Node{
int n,x,y;
};
bool bfs(int n,int x,int y){
for(int i = ; i < ; ++i)
for(int j = ; j < N; ++j)
for(int k = ; k < M; ++k)
len[i][j][k] = inf;
mem(vis,);
queue<Node>que;
que.push((Node){.n=n,.x=x,.y=y});
vis[n][x][y] = ;
len[n][x][y] = ;
while(que.size()){
Node p = que.front();
que.pop();
// cout<<p.n<<" "<<p.x<<" "<<p.y<<endl;
if(maze[p.n][p.x][p.y]=='P'){
return true;
}
for(int i = ; i < ; ++i){
nx = p.x + dirx[i];
ny = p.y + diry[i];
if(nx< || nx >= N || ny < || ny >= M )
continue;
nn = (maze[p.n][nx][ny] == '#'?int(p.n^):p.n);
if(!vis[nn][nx][ny]&&maze[nn][nx][ny]!='*'){
que.push((Node){.n=nn,.x=nx,.y=ny});
vis[nn][nx][ny]=;
int temp = (maze[p.n][nx][ny]=='#'?:);
len[nn][nx][ny] = len[p.n][p.x][p.y]+; }
}
}
return false;
}
int main(){
//std::ios::sync_with_stdio(false);
//std::cin.tie(0);
#ifndef ONLINE_JUDGE
freopen("D:\\in.txt","r",stdin);
freopen("D:\\out.txt","w",stdout);
#else
#endif
int t;
scanf("%d",&t);
while(t--){
scanf("%d%d%d",&N,&M,&T);
for(int i = ; i < ; ++i){
for(int j = ; j < N; ++j){
cin>>maze[i][j];
for(int k = ; k < M; ++k){
if(maze[i][j][k]=='P'){
pn = i,px = j,py = k;
}
}
}
}
for(int j = ; j < N; ++j){
for(int k = ; k < M; ++k){
if((maze[][j][k]==maze[][j][k]&&(maze[][j][k]=='#'))||(maze[][j][k]=='*'&&maze[][j][k]=='#')||(maze[][j][k]=='#'&&maze[][j][k]=='*')){
maze[][j][k] = '*';
maze[][j][k] = '*';
}
}
}
bool ans = bfs(,,);
// cout<<len[pn][px][py]<<endl;
if(ans&&len[pn][px][py] <= T)
cout<<"YES"<<endl;
else
cout<<"NO"<<endl; }
return ;
}

I - A计划 HDU - 2102的更多相关文章

  1. A计划 HDU - 2102

    A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  2. hdu 2102 A计划

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2102 A计划 Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸 ...

  3. HDU 2102 A计划(两层地图加时间限制加传送门的bfs)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2102 A计划 Time Limit: 3000/1000 MS (Java/Others)    Me ...

  4. hdu - 2102 A计划 (简单bfs)

    http://acm.hdu.edu.cn/showproblem.php?pid=2102 题目还是不难,注意起点一定是(0,0,0),然后到达P点时间<=t都可以. 用一个3维字符数组存储图 ...

  5. hdu 2102 A计划(优先队列+dfs)

    改了好久,上午来实验室打出来了,运行就是不对,一直找啊找!还是没找到,最后突然停电了,打好的代码还没保存呢! 刚才来的时候又重新打了一遍!!!结果一个小小的错误wrong了好久!!! 在dfs值返回时 ...

  6. hdu 2102 A计划(双层BFS)(具体解释)

    转载请注明出处:http://blog.csdn.net/u012860063?viewmode=contents 题目链接:http://acm.hdu.edu.cn/showproblem.php ...

  7. [HDU 2102] A计划(搜索题,典型dfs or bfs)

    A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  8. HDU 2102 A计划(BFS/DFS走迷宫)

    A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  9. HDU 2102 A计划(BFS)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2102 题目大意:公主被关在一个两层的迷宫里,迷宫的入口是S(0,0,0),公主的位置用P表示,时空传输 ...

随机推荐

  1. 部署企业本地yum源及源码包安装

    YUM命令 yum list //列出每个软件包(包括未安装和已安装) rpm -q repolist //列出所以仓库名称 info //查看软件信息 rpm -qi install //安装 rp ...

  2. 关于Java中注解的总结

    注解用来给类声明附加额外信息,可以标注在类.字段.方法等上面,编译器.JVM以及开发人员等都可以通过反射拿到注解信息,进而做一些相关处理 Java中注解的知识结构图 常用注解 @Override   ...

  3. 《运筹学基础及应用》习题1.1(b),1.1(c),1.2(a)

    用图解法求解下列线性规划问题,并指出问题具有惟一最优解,无穷多最优解,无界解还是无可行解. 习题1.1(b):$\max z=3x_1+2x_2$$$s.t\begin{cases}  2x_1+x_ ...

  4. TCP并发、GIL、锁

    TCP实现并发 #client客户端 import socket client = socket.socket() client.connect(('127.0.0.1',8080)) while T ...

  5. 4)mysqlDB

    (1)首先是变量声明 (2)函数注释 (3)__contruct函数的编写(可有可无) (4)getInstance函数编写(这个是获得这个mysqlDB类的实例对象) 编写代码: (5)然后是其他功 ...

  6. Margin of Error|sample size and E

    8.3 Margin of Error 由该公式可知: To improve the precision of the estimate, we need to decrease the margin ...

  7. [LC] 246. Strobogrammatic Number

    A strobogrammatic number is a number that looks the same when rotated 180 degrees (looked at upside ...

  8. Welcome to Fan Ouyang’s website!

    Welcome to Fan Ouyang's website! 欧阳璠,哲学博士,湖南娄底人. 目前为浙江大学教育学院课程与学习科学系教育技术专业百人计划研究员. 2013-2018年 明尼苏达大学 ...

  9. vue项目根目录下index.html中的id="app",与src目录下的App.vue中的id="app"为什么不会冲突

    感谢:https://blog.csdn.net/qq_35624642/article/details/78243413 index.html <body> <div id=&qu ...

  10. Cenos配置Android集成化环境, 最终Centos libc库版本过低放弃

    To honour the JVM settings for this build a new JVM will be forked. Please consider using the daemon ...