I'm stuck

试题编号: 201312-5
试题名称: I’m stuck!
时间限制: 1.0s
内存限制: 256.0MB
问题描述:
问题描述
  给定一个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

问题链接:CCF201312试题

问题描述:参见上文。

问题分析:这个问题可以用DFS(深度优先搜索)来解决,需要两次DFS。先从“S”点开始搜索,找出其可以到达的点。这是如果从“S”点不可以到达“T”点,则输出"I'm stuck!",否则从“S”点可以到达点开始,逐个搜索其可到达的点,统计那些不可到达“T”点的数量即可。

程序说明:(略)。

提交后得100分的C++语言程序如下:

/* CCF201312-5 I’m stuck! */

#include <iostream>

#include <cstring>

using namespace std;

const int N = ;

const int DIRECTSIZE = ;

struct _direct {

    int dr, dc;

} direct[DIRECTSIZE] = {{-, }, {, }, {, -}, {, }};

char grid[N][N+];

int visited[N][N], visited2[N][N];

int R, C;

// 判断坐标是否合法或可移动到

inline bool islegal(int r, int c)

{

    if( <= r && r < R &&  <= c && c < C && !visited[r][c] && grid[r][c] != '#')

        return true;

    else

        return false;

}

// 深度优先搜索

void dfs(int r, int c)

{

    int nextr, nextc;

    visited[r][c] = ;

    if(grid[r][c] == '+' || grid[r][c] == 'S' || grid[r][c] == 'T') {

        for(int i=; i<DIRECTSIZE; i++) {

            nextr = r + direct[i].dr;

            nextc = c + direct[i].dc;

            if(islegal(nextr, nextc))

                dfs(nextr, nextc);

        }

    } else if(grid[r][c] == '-') {

        for(int i=; i<DIRECTSIZE; i++) {

            nextr = r + direct[i].dr;

            nextc = c + direct[i].dc;

            if(islegal(nextr, nextc))

                dfs(nextr, nextc);

        }

    } else if(grid[r][c] == '|') {

        for(int i=; i<; i++) {

            nextr = r + direct[i].dr;

            nextc = c + direct[i].dc;

            if(islegal(nextr, nextc))

                dfs(nextr, nextc);

        }

    } else if(grid[r][c] == '.') {

        nextr = r + direct[].dr;

        nextc = c + direct[].dc;

        if(islegal(nextr, nextc))

            dfs(nextr, nextc);

    }

}

int main()

{

    int sr, sc, tr, tc;

    // 输入数据

    cin >> R >> C;

    for(int i=; i<R; i++)

        cin >> grid[i];

    // 找到起点和终点坐标

    for(int i=; i<R; i++)

        for(int j=; j<C; j++)

            if(grid[i][j] == 'S')

                sr = i, sc = j;

            else if(grid[i][j] == 'T')

                tr = i, tc = j;

    // bfs:标记从"S"点可以到达的点

    memset(visited, , sizeof(visited));

    dfs(sr, sc);

    memcpy(visited2, visited, sizeof(visited));

    if(visited2[tr][tc]) {

        int count = ;

        // 统计"S"点可以到达、而不可到达"T"点的数量

        for(int i=; i<R; i++)

            for(int j=; j<C; j++) {

                if(visited2[i][j]) {    // "S"点可以到达的<i,j>点

                    // bfs:标记从<i,j>点开始可以到达的点,如果不能到达"T"点则计数

                    memset(visited, , sizeof(visited));

                    dfs(i, j);

                    if(!visited[tr][tc])

                        count++;

                }

            }

        // 输出结果

        cout << count << endl;

    } else

        // 从"S"点不可以到达"T"点

        cout << "I'm stuck!" << endl;

    return ;

}

CCF-CSP 201312-5 I'm stuck !的更多相关文章

  1. CCF CSP 认证

    参加第八次CCF CSP认证记录 代码还不知道对不对,过两天出成绩. 成绩出来了,310分. 100+100+100+10+0: 考试13:27开始,17:30结束,提交第4题后不再答题,只是检查前四 ...

  2. CCF CSP 201609-2 火车购票

    题目链接:http://118.190.20.162/view.page?gpid=T46 问题描述 请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配. 假设一节车厢有20排.每一排 ...

  3. CCF CSP 201703-3 Markdown

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201703-3 Markdown 问题描述 Markdown 是一种很流行的轻量级标记语言(l ...

  4. CCF CSP 201703

    CCF CSP 2017·03 做了一段时间的CCF CSP试题,个人感觉是这样分布的 A.B题基本纯暴力可满分 B题留心数据范围 C题是个大模拟,留心即可 D题更倾向于图论?(个人做到的D题基本都是 ...

  5. CCF CSP 201312-3 最大的矩形

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201312-3 最大的矩形 问题描述 在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i( ...

  6. CCF CSP 201609-3 炉石传说

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201609-3 炉石传说 问题描述 <炉石传说:魔兽英雄传>(Hearthston ...

  7. CCF CSP 201403-3 命令行选项

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201403-3 命令行选项 问题描述 请你写一个命令行分析程序,用以分析给定的命令行里包含哪些 ...

  8. CCF CSP 201709-4 通信网络

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201709-4 通信网络 问题描述 某国的军队由N个部门组成,为了提高安全性,部门之间建立了M ...

  9. CCF CSP 201409-3 字符串匹配

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201409-3 字符串匹配 问题描述 给出一个字符串和多行文字,在这些文字中找到字符串出现的那 ...

  10. CCF CSP 201503-3 节日

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201503-3 节日 问题描述 有一类节日的日期并不是固定的,而是以“a月的第b个星期c”的形 ...

随机推荐

  1. P2153 [SDOI2009]晨跑

    思路 典型的最小费用最大流问题,拆点,每个点对应的入点和出点之间连一条cap=1的边表示只能经过一次的限制条件 然后其他边从u的出点连向v的入点即可 代码 #include <cstdio> ...

  2. 深度学习课程笔记(十四)深度强化学习 --- Proximal Policy Optimization (PPO)

    深度学习课程笔记(十四)深度强化学习 ---  Proximal Policy Optimization (PPO) 2018-07-17 16:54:51  Reference: https://b ...

  3. (转) 干货 | 图解LSTM神经网络架构及其11种变体(附论文)

    干货 | 图解LSTM神经网络架构及其11种变体(附论文) 2016-10-02 机器之心 选自FastML 作者:Zygmunt Z. 机器之心编译  参与:老红.李亚洲 就像雨季后非洲大草原许多野 ...

  4. Kubernetes工作流之Pods二

    Init Containers This feature has exited beta in 1.6. Init Containers can be specified in the PodSpec ...

  5. git core.autocrlf配置 解决Windows和Linux(Mac)换行问题

    格式化 格式化是许多开发人员在协作时,特别是在跨平台情况下,遇到的令人头疼的细小问题. 由于编辑器的不同或者Windows程序员在跨平台项目中的文件行尾加入了回车换行符, 一些细微的空格变化会不经意地 ...

  6. Spring-Mybatis依赖

    <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis --><dependency> <groupId& ...

  7. RN 调用安卓的原生方法(实现Toast效果)

    首先明确一点,坑实在是是太多了-神奇呀! ok! 基本思路: 1.用AS打开一个已经存在的项目(这里可以打开项目中的android也可以是android里面的build.gradle) 2.在AS里新 ...

  8. dataTables使用整理(一)

    初次使用dataTables,对一些用到的属性及遇到的问题做一个简要的记录 参考资料: http://blog.csdn.net/mickey_miki/article/details/8240477 ...

  9. hdu 3832 Earth Hour bfs

    Earth Hour Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 125536/65536 K (Java/Others) Prob ...

  10. P4001 [BJOI2006]狼抓兔子

    传送门 思路: 不少题解都是用网络流来做最小割(网络流是什么),但对于一个不会网络流的蒟蒻来做这题相当困难. 听机房daolao说可以重构图做最短路.然后就baidu将平面图转换成一个对偶图,因为网络 ...