A计划

Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other)
Total Submission(s) : 26   Accepted Submission(s) : 2

Font: Times New Roman | Verdana | Georgia

Font Size: ← →

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

公主被绑架了,你有迷宫的地图,该迷宫只有两层楼#表示楼梯,.表示空地,*表示墙,第一行输入N,M,K,表示需要输入两个N*M的矩阵地图,起始点为S,公主的位置为P,问你能否在限定的K步之内,找到公主。如果能的话输出YES,否则输出NO.

HDU 2007-6 Programming Contest

 #include <stdio.h>
#include <stdlib.h>
int Len_X,Len_Y,D,SIGN;
char Map[][][];
int DFS(int x,int y,int z,int d,int D)
{
int ii,jj;
if(SIGN==)return ;
if(x>=Len_X||x<||y>=Len_Y||y<||d>D)return ;
if(d<=D&&Map[x][y][z]=='P'){SIGN=;return ;}
if(Map[x][y][z]=='#')
{
if(z==&&(Map[x][y][]!='*'&&Map[x][y][]!='#'))
{
DFS(x,y,,d,D);Map[x][y][]='.';return ;
}
else if(z==&&(Map[x][y][]!='*'&&Map[x][y][]!='#'))
{
DFS(x,y,,d,D);Map[x][y][]='.';return ;
}
else return ;
}
if(d>=D)return ;
if(Map[x][y][z]=='*')return ;
else Map[x][y][z]='*';
/* getch();
putchar('\n');
printf("\tStyp: %d\n",d);
for(ii=0;ii<Len_X;ii++)
{
if(z==1)putchar('\t');
for(jj=0;jj<Len_Y;jj++)
{
printf("%c",Map[ii][jj][z]);
}
putchar('\n');
}*/
if(x+<Len_X&&Map[x+][y][z]!='*')
{
DFS(x+,y,z,d+,D);
if(Map[x+][y][z]!='#')
Map[x+][y][z]='.';
}
if(x->=&&Map[x-][y][z]!='*')
{
DFS(x-,y,z,d+,D);
if(Map[x-][y][z]!='#')
Map[x-][y][z]='.';
}
if(y+<Len_Y&&Map[x][y+][z]!='*')
{
DFS(x,y+,z,d+,D);
if(Map[x][y+][z]!='#')
Map[x][y+][z]='.';
}
if(y->=&&Map[x][y-][z]!='*')
{
DFS(x,y-,z,d+,D);
if(Map[x][y-][z]!='#')
Map[x][y-][z]='.';
}
return ;
} int main()
{
int Begin_x,Begin_y,Begin_z,i,j,T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&Len_X,&Len_Y,&D);
getchar();
for(i=;i<Len_X;i++)
{
for(j=;j<Len_Y;j++)
{
scanf("%c",&Map[i][j][]);
if(Map[i][j][]=='S')
{Begin_x=i;Begin_y=j;Begin_z=;}
}
getchar();
}
getchar();
for(i=;i<Len_X;i++)
{
for(j=;j<Len_Y;j++)
{
scanf("%c",&Map[i][j][]);
if(Map[i][j][]=='S')
{Begin_x=i;Begin_y=j;Begin_z=;}
}
getchar();
}
SIGN=;
DFS(Begin_x,Begin_y,Begin_z,,D);
if(SIGN==)
printf("YES\n");
else
printf("NO\n");
}
return ;
}

修改:2015.5.8

 #include <stdio.h>
#include <stdlib.h>
int Len_X,Len_Y,D,SIGN;
int Begin_x,Begin_y,Begin_z;
char Map[][][];
void DFS(int x,int y,int z,int d,int D)
{
// printf("\t%d %d %d\n",x,y,z);
if(SIGN==)return ;
if(d>D)return ;
if(Map[x][y][z]=='*')return;
if(d<=D&&Map[x][y][z]=='P'){SIGN=;return ;}
if(Map[x][y][z]=='#')
{
Map[x][y][z]='*';
if(z==)DFS(x,y,,d,D);
else DFS(x,y,,d,D);
Map[x][y][z]='#';
}
else if(Map[x][y][z]=='.')
{
Map[x][y][z]='*';
DFS(x-,y,z,d+,D);
DFS(x+,y,z,d+,D);
DFS(x,y-,z,d+,D);
DFS(x,y+,z,d+,D);
Map[x][y][z]='.';/*和步数有关,需要点还原*/
}
return ;
}
void Input(int z)/*输入地图*/
{
int i,j;
for(i=;i<=Len_X+;i++)
{
for(j=;j<=Len_Y+;j++)
{
if(i==||j==||i==Len_X+||j==Len_Y+){Map[i][j][z]='*';}
else
{
scanf(" %c",&Map[i][j][z]);
if(Map[i][j][]=='S')
{
Map[i][j][]='.';
Begin_x=i;Begin_y=j;Begin_z=;
}
}
}
}
return ;
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&Len_X,&Len_Y,&D);
Input();Input(); SIGN=;
DFS(Begin_x,Begin_y,Begin_z,,D);
if(SIGN==) printf("YES\n");
else printf("NO\n");
}
return ;
}

A计划的更多相关文章

  1. 【声明】前方不设坑位,不收费!~ 我为NET狂官方学习计划

    发个通知,过段时间学习计划相关的东西就出来了,上次写了篇指引文章后有些好奇心颇重的人跟我说:“发现最近群知识库和技能库更新的频率有点大,这是要放大招的节奏啊!” 很多想学习却不知道如何规划的人想要一个 ...

  2. SQL Server-聚焦查询计划Stream Aggregate VS Hash Match Aggregate(二十)

    前言 之前系列中在查询计划中一直出现Stream Aggregate,当时也只是做了基本了解,对于查询计划中出现的操作,我们都需要去详细研究下,只有这样才能对查询计划执行的每一步操作都了如指掌,所以才 ...

  3. ORACLE从共享池删除指定SQL的执行计划

    Oracle 11g在DBMS_SHARED_POOL包中引入了一个名为PURGE的新存储过程,用于从对象库缓存中刷新特定对象,例如游标,包,序列,触发器等.也就是说可以删除.清理特定SQL的执行计划 ...

  4. 解析大型.NET ERP系统核心组件 查询设计器 报表设计器 窗体设计器 工作流设计器 任务计划设计器

    企业管理软件包含一些公共的组件,这些基础的组件在每个新项目立项阶段就必须考虑.核心的稳定不变功能,方便系统开发与维护,也为系统二次开发提供了诸多便利.比如通用权限管理系统,通用附件管理,通用查询等组件 ...

  5. MSSQLSERVER执行计划详解

    序言 本篇主要目的有二: 1.看懂t-sql的执行计划,明白执行计划中的一些常识. 2.能够分析执行计划,找到优化sql性能的思路或方案. 如果你对sql查询优化的理解或常识不是很深入,那么推荐几骗博 ...

  6. SQL Server-聚焦使用索引和查询执行计划(五)

    前言 上一篇我们讲了聚集索引对非聚集索引的影响,对数据库一直在强调的性能优化,所以这一节我们统筹讲讲利用索引来看看查询执行计划是怎样的,简短的内容,深入的理解,Always to review the ...

  7. SQL Tuning 基础概述03 - 使用sql_trace和10046事件跟踪执行计划

    1.使用sql_trace跟踪执行计划 1.1 当前session跟踪: alter session set sql_trace = true; //开始sql_trace alter session ...

  8. SELECT TOP 1 比不加TOP 1 慢的原因分析以及SELECT TOP 1语句执行计划预估原理

    本文出处:http://www.cnblogs.com/wy123/p/6082338.html 现实中遇到过到这么一种情况: 在某些特殊场景下:进行查询的时候,加了TOP 1比不加TOP 1要慢(而 ...

  9. SQL Server 执行计划利用统计信息对数据行的预估原理二(为什么复合索引列顺序会影响到执行计划对数据行的预估)

    本文出处:http://www.cnblogs.com/wy123/p/6008477.html 关于统计信息对数据行数做预估,之前写过对非相关列(单独或者单独的索引列)进行预估时候的算法,参考这里. ...

  10. ASP.NET Core官方计划路线及需要废除的一些Framework技术

    概述 下面是 ASP.NET Core的时间表和路线图. 注意日期和特性都可能更改. 作为.NET Core这么大的一个项目,很难准确预测每一个计划的是否有变动. 即便如此,我们还是计划公开和透明的实 ...

随机推荐

  1. Redis6-sorted set 的介绍

    Sort Set排序集合类型(1)介绍和set一样sorted set也是string类型元素的集合,不同的是每个元素都会关联一个权.通过权值可以有序的获取集合中的元素该Sort Set类型适合场合: ...

  2. zookeeper 安装 windows环境

    1.zookeeper下载地址: http://mirrors.cnnic.cn/apache/zookeeper/ 2.单点配置 把下载的zookeeper的文件解压到指定目录 修改conf下增加一 ...

  3. MD5加密 js文件

    var hexcase = 0; var b64pad = ""; var chrsz = 8; function hex_md5(s){ return binl2hex(core ...

  4. webuploader问题

    pick里面的id,我理解就是有点选择器的意思,目前我的认知是不设置它就无法取文件操作: 然后,查看页面的时候发现,pick通过id选定的元素,被替换成了webuploader自定义的元素,表现是-- ...

  5. const形参与非const形参

    在程序设计中我们会经常调用函数,调用函数就会涉及参数的问题,那么在形参列表中const形参与非const形参对传递过来的实参有什么要求呢? 先来看一个简单的例子: #include <iostr ...

  6. hdu_4283_You Are the One(区间DP)

    题目链接:hdu_4283_You Are the One 题意: 有n个人,每个人有个屌丝值,如果果他是第K个上场,不开心指数就为(K-1)*D,然后有个小黑屋,可以调整他们的出场顺序,现在让你调整 ...

  7. file_zilla 通过key连接远程服务器

    file_zilla 通过key连接 01 在putty中 ifconfig -a 查看当前网站ip02 文件-站点管理器--新建站点---主机ip 端口2203协议 SFTP 就是SSH协议04登录 ...

  8. c++的输入和输出流

    C++编译系统提供了用于输入输出的iostream类库.iostream这个单词是由3个部 分组成的,即i-o-stream,意为输入输出流.在iostream类库中包含许多用于输入输出的 类.常用的 ...

  9. Lua手册中的string.len 不解

    Lua手册中的string.len (s) 接收一个字符串,返回其长度. 空串 "" 的长度为 0 . 内嵌零也统计在内,因此 "a\000bc\000" 的长 ...

  10. Just do it!!!

    从今日起,开个开发自己个人轻量级博客,加油!!!!!