CCF模拟 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'。
5 5
--+-+
..|#.
..|##
S-+-T
####.
如果把满足性质的方格在地图上用'X'标记出来的话,地图如下所示:
--+-+
..|#X
..|##
S-+-T
####X
解题:直接搜索了。。。
#include <iostream>
#include <cstdio>
#include <queue>
#include <cstring>
#define pii pair<int,int>
using namespace std;
const int maxn = ;
char mp[maxn][maxn];
bool va[maxn][maxn],vb[maxn][maxn],e[maxn*maxn][maxn*maxn];
int n,m,sx,sy,tx,ty;
const int dir[][] = {-,,,-,,,,};
bool isIn(int x,int y){
return x >= && x < n && y >= && y < m;
}
void select(int &x,int &y,pii &now){
switch(mp[now.first][now.second]){
case '+':x = ,y = ;break;
case '|':x = ,y = ;break;
case '-':x = ,y = ;break;
case '.':x = ,y = ;break;
}
}
bool bfs(){
queue< pii >q;
q.push(make_pair(sx,sy));
memset(va,false,sizeof(va));
va[sx][sy] = true;
memset(e,false,sizeof(e));
while(!q.empty()){
pii now = q.front();
q.pop();
int st,sp;
select(st,sp,now);
for(int i = st; i < ; i += sp){
int ox = dir[i][] + now.first;
int oy = dir[i][] + now.second;
if(isIn(ox,oy) && mp[ox][oy] != '#'){
e[ox*m+oy][now.first*m+now.second] = true;
if(!va[ox][oy]){
va[ox][oy] = true;
q.push(make_pair(ox,oy));
}
}
}
}
return va[tx][ty];
}
void bfs2(){
queue< pii >q;
q.push(make_pair(tx,ty));
memset(vb,false,sizeof(vb));
vb[tx][ty] = true;
while(!q.empty()){
pii now = q.front();
q.pop();
for(int i = ; i < ; ++i){
int ox = dir[i][] + now.first;
int oy = dir[i][] + now.second;
if(isIn(ox,oy)&&e[now.first*m+now.second][ox*m+oy]&&!vb[ox][oy]){
vb[ox][oy] = true;
q.push(make_pair(ox,oy));
}
}
}
}
int main(){
while(~scanf("%d %d",&n,&m)){
for(int i = ; i < n; ++i){
scanf("%s",mp[i]);
for(int j = ; j < m; ++j)
if(mp[i][j] == 'S'){
sx = i;
sy = j;
mp[i][j] = '+';
}else if(mp[i][j] == 'T'){
tx = i;
ty = j;
mp[i][j] = '+';
}
}
if(bfs()){
bfs2();
int ans = ;
for(int i = ; i < n; ++i)
for(int j = ; j < m; ++j)
if(va[i][j] && !vb[i][j]) ans++;
cout<<ans<<endl;
}else puts("I'm stuck!");
}
return ;
}
CCF模拟 I’m stuck!的更多相关文章
- CCF 模拟试题——出现次数最多的数 官方答案解析及自己写的正确答案
		
前几天知道的CCF计算机职业资格认证考试,觉得好像比软考含金量高一些,就去了解了一下,做了模拟试题中的 “出现次数最多的数” 这道题,我的算法和官方答案算法不同,个人觉得觉得官方的好一点,没那么繁琐, ...
 - CCF 模拟E DFS深搜
		
http://115.28.138.223:81/view.page?opid=5 这道题问的很怪. 起点DFS,每一个点还要DFS一次,统计不能到终点的个数 数据量不大这样做也能AC #includ ...
 - CCF 201312-5	I’m stuck! (暴力,BFS)
		
问题描述 给定一个R行C列的地图,地图的每一个方格可能是'#', '+', '-', '|', '.', 'S', 'T'七个字符中的一个,分别表示如下意思: '#': 任何时候玩家都不能移动到此方格 ...
 - CCF模拟题 窗口
		
窗口 时间限制: 1.0s 内存限制: 256.0MB 问题描述 在某图形操作系统中,有 N 个窗口,每个窗口都是一个两边与坐标轴分别平行的矩形区域.窗口的边界上的点也属于该窗口.窗口之间有层次的 ...
 - CCF 模拟D 动态规划
		
http://115.28.138.223:81/view.page?opid=4 这道题写的我醉醉的,想建一棵指定深度的树最后统计满足条件的个数 居然没去考虑这样必然超时!!!代码写的也是醉了,把没 ...
 - CCF 模拟C 找最大矩形+输入输出外挂
		
http://115.28.138.223:81/view.page?opid=3 统计出连续的最长乘以当前高度,找最大即可 #include<iostream> #include< ...
 - CCF 模拟B 无脑循环+输入输出外挂
		
http://115.28.138.223:81/view.page?opid=2#code 代码一有WA点80分 #include<iostream> #include<cstdi ...
 - CCF 模拟A 无脑大循环
		
http://115.28.138.223:81/view.page?opid=1 第一题用一组STL函数查找即可 #include<iostream> #include<cstdi ...
 - (ccf模拟)201709-2公共钥匙盒
		
#include <iostream> #include<string> #include <algorithm> #include<sstream> ...
 
随机推荐
- XXXfragment that is not a fragment错误,fragment认不出来
			
要注意的是fragment事实上是有两个版本号的,一个是 import android.support.v4.app.Fragment; 另外一个是 import android.app.Fragme ...
 - WebAPI的自动化监控和预警
			
Metrics.net + influxdb + grafana 构建WebAPI的自动化监控和预警 前言 这次主要分享通过Metrics.net + influxdb + grafana 构建Web ...
 - ModelForm views.py
			
from django.shortcuts import render from django import forms from django.forms import fields from ap ...
 - AngularJs轻松入门(八)Cookies读写
			
虽然使用JavaScript创建和获取Cookie很简单,AngularJs还是把它作为一个单独的模块进行了封装,模块名为ngCookies,和前面的教程中做法一样,先引入angular-cookie ...
 - 给 “rm” 命令添加个“垃圾桶”
			
作者: 2daygeek 译者: LCTT amwps290 人类犯错误是因为我们不是一个可编程设备,所以,在使用 rm 命令时要额外注意,不要在任何时候使用 rm -rf *.当你使用 rm 命令时 ...
 - MVC-easyui-EF
			
easyui+jQuery+MVC+EF的一个演示 环境:visual studio 2013+sql server 创建新项目:visual C# -> Web -> visual st ...
 - java开发微信公众号支付(JSAPI)
			
https://www.cnblogs.com/gopark/p/9394951.html,这篇文章写的已经很详细了. 下面写一下自己的思路: 1.首先下载demo,地址:https://pay.we ...
 - python描述符和属性查找
			
python描述符 定义 一般说来,描述符是一种访问对象属性时候的绑定行为,如果这个对象属性定义了__get__(),__set__(), and __delete__()一种或者几种,那么就称之为描 ...
 - 赋值、复制构造函数和构造函数 & 异常安全的赋值
			
异常安全的赋值 需要注意,复制赋值和复制构造,相兼容. 赋值时候,要带上自检查.
 - 为什么用卷积滤波,而不是非常easy的在频率领域内进行数据的频率处理
			
卷积.为了更好的"动态"滤波. 问题来了.为什么用卷积滤波.而不是非常easy的在频率领域内进行数据的频率处理? 为了强调我觉得的答案,已经用blog标题给出了.卷积.为了更好的& ...