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. class.forName() 和 classLoader 的区别

    相同点:        java中class.forName() 和 classLoader 都可用来对类进行加载 不同店:        1.class.forName()除了将类的 .class ...

  2. day09-正侧表达式

    while True: phone_num = input('please input your phone_num:') if len(phone_num) == 11 \ and phone_nu ...

  3. scala编程(八)——函数和闭包

    当程序变得庞大时,你需要一些方法把它们分割成更小的,更易管理的片段.为了分割控制流,Scala 提供了所有有经验的程序员都熟悉的方式:把代码分割成函数.实际上,Scala 提供了许多 Java 中没有 ...

  4. SPI以及IIC的verilog实现以及两者之间的对比

    一.SPI是一种常用的串行通信接口,与UART不同的地方在于.SPI可以同时挂多个从机,但是UART只能点对点的传输数据,此外SPI有四条线实现数据的传输,而UART采用的是2条实现串行数据的传输 1 ...

  5. Linux文件属性和权限

     Linux文件属性 第一栏:表示文件类型和权限 文件的类型:  d:目录    -:文件    l:链接文件    b:可存储设备    c:可输入设备 第一组:表示拥有者权限 第二组:表示该组的权 ...

  6. window server 2012+apache+django

    一.apache下载安装 https://www.apachelounge.com/download/VC10/ ***注意*** 本人用的是window server 2012 64位版本云服务器, ...

  7. php防止post数据刷新重复刷新。后退 等重复提交?

    目前测试最好的办法:同步令牌(Token)机制来解决Web应用中重复提交的问题.还在研究中,稍后带来

  8. dotfuscator安装

    1.vs 2017 安装 dotfuscator 组件 打开vs 2017 按 ctrl + Q在输入框中输入“dotfuscator” ,选中第一个. 2.安装完成后即可在vs的工具中看到该组件 3 ...

  9. 题解:线性规划与网络流24题 T2 太空飞行计划问题

    太空飞行计划问题 问题描述 W教授正在为国家航天中心计划一系列的太空飞行.每次太空飞行可进行一系列商业性实验而获取利润.现已确定了一个可供选择的实验集合E={E1,E2,-,Em},和进行这些实验需要 ...

  10. 转发: python3.7下 Flask-SQLAlchemy中解决1366报错

    原链接:https://segmentfault.com/a/1190000010596306 详情: 安装MySQL驱动(我升级过Python,所以要再装一遍) 本想安装MySQL官方驱动mysql ...