ccf-I’m stuck!

给定一个R行C列的地图,地图的每一个方格可能是‘#‘, ‘+‘, ‘-‘, ‘|‘, ‘.‘, ‘S‘, ‘T‘七个字符中的一个,分别表示如下意思:

‘#‘: 任何时候玩家都不能移动到此方格;

‘+‘: 当玩家到达这一方格后,下一步可以向上下左右四个方向相邻的任意一个非‘#‘方格移动一格;

‘-‘: 当玩家到达这一方格后,下一步可以向左右两个方向相邻的一个非‘#‘方格移动一格;

‘|‘: 当玩家到达这一方格后,下一步可以向上下两个方向相邻的一个非‘#‘方格移动一格;

‘.‘: 当玩家到达这一方格后,下一步只能向下移动一格。如果下面相邻的方格为‘#‘,则玩家不能再移动;

‘S‘: 玩家的初始位置,地图中只会有一个初始位置。玩家到达这一方格后,下一步可以向上下左右四个方向相邻的任意一个非‘#‘方格移动一格;

‘T‘: 玩家的目标位置,地图中只会有一个目标位置。玩家到达这一方格后,可以选择完成任务,也可以选择不完成任务继续移动。如果继续移动下一步可以向上下左右四个方向相邻的任意一个非‘#‘方格移动一格。

此外,玩家不能移动出地图。

请找出满足下面两个性质的方格个数:

1. 玩家可以从初始位置移动到此方格;

2. 玩家可以从此方格移动到目标位置。

输入格式

输入的第一行包括两个整数R 和C,分别表示地图的行和列数。(1 ≤ R, C ≤ 50)。

接下来的R行每行都包含C个字符。它们表示地图的格子。地图上恰好有一个‘S‘和一个‘T‘。

输出格式

如果玩家在初始位置就已经不能到达终点了,就输出“I‘m stuck!”(不含双引号)。否则的话,输出满足性质的方格的个数。

样例输入

5 5

--+-+

..|#.

..|##

S-+-T

####.

样例输出

2

样例说明

如果把满足性质的方格在地图上用‘X‘标记出来的话,地图如下所示:

--+-+

..|#X

..|##

S-+-T

####X

#include <iostream>
#include <algorithm>
#include <string.h>
#include <cmath>
#include <stdio.h>
#include <queue>
#define maxn 60
char mmap[maxn][maxn];
int vis[maxn][maxn];
int vis1[maxn][maxn];
int dy[4] = {0, 0, -1, 1};
int dx[4] = {1, -1, 0, 0};
int n, m;
int num[maxn][maxn][maxn][maxn];
using namespace std;
struct Node
{
    int x;
    int y;
    Node() {}
    Node(int _x, int _y) {
        x = _x;
        y = _y;
    }
} node[maxn];
Node st, ed;
int check(Node a)
{
    if(a.x >= 0 && a.x < n && a.y >= 0 && a.y < m && mmap[a.x][a.y] != ‘#‘) {
        return 1;
    }
    return 0;
}
int get(char c, int& u, int& v)
{
    if(c == ‘-‘)
    {
        u = 2;
        v = 4;
    }
    else if(c == ‘|‘)
    {
        u = 0;
        v = 2;
    }
    else if(c == ‘.‘)
    {
        u = 0;
        v = 1;
    }
    else
    {
        u = 0;
        v = 4;
    }
}
queue<Node>que;
int  bfs()
{
    while(!que.empty()) {
        que.pop();
    }
    que.push(st);
    vis[st.x][st.y] = 1;
    Node tmp, now;
    while(!que.empty())
    {
        tmp = que.front();
        que.pop();
        int u, v;
        get(mmap[tmp.x][tmp.y], u, v);
        for(int i = u; i < v; i++)
        {
            now.x = tmp.x + dx[i];
            now.y = tmp.y + dy[i];
            if(check(now))
            {
                num[tmp.x][tmp.y][now.x][now.y] = 1;
                if(!vis[now.x][now.y]) {
                    vis[now.x][now.y] = 1;
                    que.push(now);
                }
            }
        }
    }
    if(vis[ed.x][ed.y] == 0)
    {
        puts("I‘m stuck!");
        return 0;
    }
    que.push(ed);
    while(!que.empty())
    {
        tmp = que.front();
        que.pop();
        for(int i = 0; i < 4; i++)
        {
            now.x = tmp.x + dx[i];
            now.y = tmp.y + dy[i];
            if(check(now) && vis1[now.x][now.y] == 0 && num[now.x][now.y][tmp.x][tmp.y])
            {
                vis1[now.x][now.y] = 1;
                que.push(now);
            }
        }
    }
    int ans = 0;
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < m; j++)
        {
            if(vis[i][j] == 1 && vis1[i][j] == 0)
            {
                ans++;
            }
        }
    }
    printf("%d\n", ans);
    return 0;
}
int main()
{
    scanf("%d %d", &n, &m);
    memset(vis, 0, sizeof(vis));
    memset(vis1, 0, sizeof(vis1));
    memset(num, 0, sizeof(num));
    for(int i = 0; i < n; i++)
    {
        scanf("%s", mmap[i]);
        for(int j = 0; j < m; j++)
        {
            if(mmap[i][j] == ‘S‘)
            {
                st.x = i;
                st.y = j;
            }
            if(mmap[i][j] == ‘T‘)
            {
                ed.x = i;
                ed.y = j;
            }
        }
    }
    bfs();
    return 0;
}

时间: 2024-10-22 08:37:36

ccf-I’m stuck!的相关文章

【ACM】CCF I’m stuck! BFS

过两天准备去考ccf了..这个信息获得的有点晚,提前熟悉一下做做模拟题,但是好像起步晚了些..不碍事不碍事,还有一天好好准备,练两道题,觉得300分还是可以过的! 就这这个题也写点考试的注意事项: 首先要注意时间,考试全程4个小时,按照估算大概1-1.5小时可以做完前面3题,然后开始啃后面的大题.一般来说,大题是一题搜索一题动态规划,一个小时一题的预估. 第二,可以携带纸质资料,平时看的最熟的算法书带上,做题目时还是尽量自己思考,需要参考再看,不要上来就狂翻书. 第三,注意节奏,一般前三题可以依

CCF模拟题5-I&#39;m stuck!

问题描述 给定一个R行C列的地图,地图的每一个方格可能是'#', '+', '-', '|', '.', 'S', 'T'七个字符中的一个,分别表示如下意思: '#': 任何时候玩家都不能移动到此方格: '+': 当玩家到达这一方格后,下一步可以向上下左右四个方向相邻的任意一个非'#'方格移动一格: '-': 当玩家到达这一方格后,下一步可以向左右两个方向相邻的一个非'#'方格移动一格: '|': 当玩家到达这一方格后,下一步可以向上下两个方向相邻的一个非'#'方格移动一格: '.': 当玩家到

CCF 201312-5 I’m stuck! (暴力,BFS)

问题描述 给定一个R行C列的地图,地图的每一个方格可能是'#', '+', '-', '|', '.', 'S', 'T'七个字符中的一个,分别表示如下意思: '#': 任何时候玩家都不能移动到此方格: '+': 当玩家到达这一方格后,下一步可以向上下左右四个方向相邻的任意一个非'#'方格移动一格: '-': 当玩家到达这一方格后,下一步可以向左右两个方向相邻的一个非'#'方格移动一格: '|': 当玩家到达这一方格后,下一步可以向上下两个方向相邻的一个非'#'方格移动一格: '.': 当玩家到

CCF模拟 I’m stuck!

I’m stuck! 时间限制: 1.0s 内存限制: 256.0MB 问题描述 给定一个R行C列的地图,地图的每一个方格可能是'#', '+', '-', '|', '.', 'S', 'T'七个字符中的一个,分别表示如下意思: '#': 任何时候玩家都不能移动到此方格: '+': 当玩家到达这一方格后,下一步可以向上下左右四个方向相邻的任意一个非'#'方格移动一格: '-': 当玩家到达这一方格后,下一步可以向左右两个方向相邻的一个非'#'方格移动一格: '|': 当玩家到达这一方格后,下一

CCF 201312-5 I’m stuck!

给定一个R行C列的地图,地图的每一个方格可能是'#', '+', '-', '|', '.', 'S', 'T'七个字符中的一个,分别表示如下意思: '#': 任何时候玩家都不能移动到此方格: '+': 当玩家到达这一方格后,下一步可以向上下左右四个方向相邻的任意一个非'#'方格移动一格: '-': 当玩家到达这一方格后,下一步可以向左右两个方向相邻的一个非'#'方格移动一格: '|': 当玩家到达这一方格后,下一步可以向上下两个方向相邻的一个非'#'方格移动一格: '.': 当玩家到达这一方格

CCF-I&#39;m stuck!(BFS)

I'm stuck! 问题描述 给定一个R行C列的地图,地图的每一个方格可能是'#', '+', '-', '|', '.', 'S', 'T'七个字符中的一个,分别表示如下意思: '#': 任何时候玩家都不能移动到此方格: '+': 当玩家到达这一方格后,下一步可以向上下左右四个方向相邻的任意一个非'#'方格移动一格: '-': 当玩家到达这一方格后,下一步可以向左右两个方向相邻的一个非'#'方格移动一格: '|': 当玩家到达这一方格后,下一步可以向上下两个方向相邻的一个非'#'方格移动一格

CCF 201503-4 网络延时

题目来自2015年03月CCF计算机职业资格认证考试 问题描述 给定一个公司的网络,由n台交换机和m台终端电脑组成,交换机与交换机.交换机与电脑之间使用网络连接.交换机按层级设置,编号为1的交换机为根交换机,层级为1.其他的交换机都连接到一台比自己上一层的交换机上,其层级为对应交换机的层级加1.所有的终端电脑都直接连接到交换机上. 当信息在电脑.交换机之间传递时,每一步只能通过自己传递到自己所连接的另一台电脑或交换机.请问,电脑与电脑之间传递消息.或者电脑与交换机之间传递消息.或者交换机与交换机

CCF试题:高速公路(Targin)

问题描述 某国有n个城市,为了使得城市间的交通更便利,该国国王打算在城市之间修一些高速公路,由于经费限制,国王打算第一阶段先在部分城市之间修一些单向的高速公路. 现在,大臣们帮国王拟了一个修高速公路的计划.看了计划后,国王发现,有些城市之间可以通过高速公路直接(不经过其他城市)或间接(经过一个或多个其他城市)到达,而有的却不能.如果城市A可以通过高速公路到达城市B,而且城市B也可以通过高速公路到达城市A,则这两个城市被称为便利城市对. 国王想知道,在大臣们给他的计划中,有多少个便利城市对. 输入

给定n个不同的整数,问这些数中有多少对整数,它们的值正好相差1(ccf真题)

ccf认证考试2014年9月第一题 问题描述 给定n个不同的整数,问这些数中有多少对整数,它们的值正好相差1. 输入格式 输入的第一行包含一个整数n,表示给定整数的个数. 第二行包含所给定的n个整数. 输出格式 输出一个整数,表示值正好相差1的数对的个数. 样例输入 6 10 2 6 3 7 8 样例输出 3 样例说明 值正好相差1的数对包括(2, 3), (6, 7), (7, 8). 评测用例规模与约定 1<=n<=1000,给定的整数为不超过10000的非负整数. #include<

图像旋转(ccf真题)

ccf认证2015年3月第一题 问题描述 旋转是图像处理的基本操作,在这个问题中,你需要将一个图像逆时针旋转90度. 计算机中的图像表示可以用一个矩阵来表示,为了旋转一个图像,只需要将对应的矩阵旋转即可. 输入格式 输入的第一行包含两个整数n, m,分别表示图像矩阵的行数和列数. 接下来n行每行包含m个整数,表示输入的图像. 输出格式 输出m行,每行包含n个整数,表示原始矩阵逆时针旋转90度后的矩阵. 样例输入 2 3 1 5 3 3 2 4 样例输出 3 4 5 2 1 3 评测用例规模与约定