HDU2102 A计划

又一个三维迷宫,问题链接:HDU2102
A计划

题意简述:虽然是三维迷宫,其实只有两层,骑士进入迷宫营救公主,找到公主即可。迷宫的入口是S(0,0,0),公主位置为‘P‘,时空传输机为‘#‘表示,墙为‘*‘表示,平地为‘.‘。层间移动只能通过时空传输机,并且不需要时间。骑士在同一层中只能前后左右移动,每移动一格花1时刻。输入n,有n组测试数据,每个测试数据有一行三个整数N、M和T以及迷宫数据,迷宫大小为N*M(1
<= N,M <=10),需要在T时刻前找到公主。问能否在限定时间内找到公主,能找到公主就输出“YES”,否则输出“NO”。

AC的C++语言程序如下:

/* HDU2102 A计划 */

#include <iostream>
#include <queue>
#include <cstring>

using namespace std;

const int DIRECTSIZE = 4;
struct direct {
    int dy, dz;
} direct[DIRECTSIZE] = {{-1, 0}, {1, 0}, {0, -1}, {0, 1}};

const int MAXN = 10;

const int L = 2;
int M, N, limit;

struct node {
    int x, y, z, level;
};

char cube[L][MAXN+2][MAXN+2];

int bfs()
{
    node start;

    start.x=0;
    start.y=1;
    start.z=1;
    start.level=0;

    queue<node> q;
    q.push(start);

    while(!q.empty())
    {
        node front = q.front();
        q.pop();

        if(cube[front.x][front.y][front.z] == 'P')
            return 1;
        else if(cube[front.x][front.y][front.z] == '*')
            continue;

        cube[front.x][front.y][front.z]='*';

        for(int i=0; i<DIRECTSIZE; i++) {
            node v;

            v.x = front.x;
            v.y = front.y + direct[i].dy;
            v.z = front.z + direct[i].dz;
            v.level = front.level + 1;

            if(cube[v.x][v.y][v.z]=='*' || v.level > limit)
                continue;
            else if(cube[v.x][v.y][v.z] == '#') {
                cube[v.x][v.y][v.z] = '*';
                v.x = 1 - v.x;
                if(cube[v.x][v.y][v.z]=='#' || cube[v.x][v.y][v.z]=='*') {
                    cube[v.x][v.y][v.z] = cube[1-v.x][v.y][v.z] = '*';
                    continue;
                }
            }

            q.push(v);
        }
    }
    return 0;
}

int main()
{
    int t, ans;

    cin >> t;
    while(t--) {
        cin >> M >> N >> limit;

        memset(cube,'*',sizeof(cube));

        for(int i=0; i<L; i++)
            for(int j=1; j<=M; j++)
                for(int k=1; k<=N; k++)
                    cin >> cube[i][j][k];

        ans = bfs();

        if(ans)
            printf("YES\n");
        else
            printf("NO\n");
    }

    return 0;
}
时间: 2024-08-13 19:40:14

HDU2102 A计划的相关文章

HDU2102 A计划 BFS 简单题 有坑点 好题

Problem Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生命的考验.魔王已经发出消息说将在T时刻吃掉公主,因为他听信谣言说吃公主的肉也能长生不老.年迈的国王正是心急如焚,告招天下勇士来拯救公主.不过公主早已习以为常,她深信智勇的骑士LJ肯定能将她救出.现据密探所报,公主被关在一个两层的迷宫里,迷宫的入口是S(0,0,0),公主的位置用P表示,时空传输机用#表示,墙用*表示,平地用.表示.骑士们一进入时空传输机就会被转到另一层的相对位置

HDU-2102 A计划

DFS可解决. #include <cstdio> #include <iostream> #include <fstream> #include <cstdlib> #include <cstring> #include <cmath> #include <algorithm> #include <queue> #define rep(i, l, r) for(int i=l; i<=r; i++) #

ACM-BFS之A计划——hdu2102

A计划 题目:http://acm.hdu.edu.cn/showproblem.php?pid=2102 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 8403 Accepted Submission(s): 1995 Problem Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生

hdu2102

题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2102 题目: A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 8731    Accepted Submission(s): 2076 Problem Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,

A计划 HDU - 2102

A计划  HDU - 2102 题目链接:https://vjudge.net/problem/HDU-2102 题目: 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生命的考验.魔王已经发出消息说将在T时刻吃掉公主,因为他听信谣言说吃公主的肉也能长生不老.年迈的国王正是心急如焚,告招天下勇士来拯救公主.不过公主早已习以为常,她深信智勇的骑士LJ肯定能将她救出. 现据密探所报,公主被关在一个两层的迷宫里,迷宫的入口是S(0,0,0),公主的位置用P表示,时空传输机

ORACLE实际执行计划与预估执行计划不一致性能优化案例

  在一台ORACLE服务器上做巡检时,使用下面SQL找出DISK_READ最高的TOP SQL分析时,分析过程中,有一条SQL语句的一些反常现象,让人觉得很奇怪: SELECT SQL_ID,        SQL_TEXT,        DISK_READS,        BUFFER_GETS,        PARSING_SCHEMA_NAME,        EXECUTIONS FROM   V$SQLAREA ORDER  BY DISK_READS DESC; 在SQL D

mysql计划任务每天定时执行

代码例子:CREATE EVENT `course_listener` ON SCHEDULE EVERY 1 DAY STARTS '2012-07-18 00:00:00' ON COMPLETION PRESERVE ENABLE DO UPDATE `om_courselist` SET `status`=6 WHERE `status`=5 AND `closetime`<CURRENT_TIMESTAMP(); 可以用navicat创建事件,更快捷: Navicat创建和设计MySQ

10.23 linux任务计划cron10.24chkconfig工具10.25 systemd管理服务10.26 unit介绍 10.27 target介绍

- 10.23 linux任务计划cron - 10.24 chkconfig工具 - 10.25 systemd管理服务 - 10.26 unit介绍 - 10.27 target介绍 - 扩展 1. anacron http://blog.csdn.net/strikers1982/article/details/4787226  2. xinetd服(默认机器没有安装这个服务,需要yum install xinetd安装) http://blog.sina.com.cn/s/blog_46

MVC与单元测试实践之健身网站(六)-计划的添加与重置

健身计划需要使用者自己定制,没有现成的内容可供选择.本篇就是关于健身计划的添加与重置功能的一部分. 一 功能描述 a) 关于计划的定制,决定以周期的方式,比如有人会以一周为周期,然后安排每周的1.3.5进行锻炼.系统将以以这种模式为典型来实现,首先需要设定一个周期循环的天数,然后为其中的某些天安排特定的锻炼内容,剩下没有安排的天数为休息时间. 为某一天安排具体的锻炼内容时,数据来自通过后台添加的训练项目,这块的功能之前已经完成.因为训练项目分成了两类,一类是对局部肌肉的锻炼,另一类是全身性的综合