cdoevs 3100 蜗牛

 时间限制: 1 s
 空间限制: 32000 KB
 题目等级 : 黄金 Gold
题目描述 Description

萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120)。
她总是从棋盘的左上角出发。棋盘上有空的格子(用“.”来表示)和B 个路障(用“#”来表示)。萨丽总是垂直(向上或者向下)或水平(向左或者向右)地走。她可以从出发地(总是记

作A1 )向下或者向右走。一旦萨丽选定了一个方向,她就会一直走下去。如果她遇到棋盘
边缘或者路障,她就停下来,并且转过90 度。她不可能离开棋盘,或者走进路障当中。并且,
萨丽从不跨过她已经经过的格子。当她再也不能走的时候,她就停止散步。
萨丽向右走,再向下,向右,向下,然后向左,再向上,最后向右走。这时她遇到了一个
她已经走过的格子,她就停下来了。但是,如果她在F5 格遇到路障后选择另外一条路——向我
们看来是左边的方向转弯,情况就不一样了。
你的任务是计算并输出,如果萨丽聪明地选择她的路线的话,她所能够经过的最多格子数。

输入描述 Input Description

输入的第一行包括N —棋盘的大小,和B —路障的数量(1 <= B <= 200)。接下来的
B 行包含着路障的位置信息。下面的样例输入对应着上面的示例棋盘。下面的输出文件表示问
题的解答。注意,当N > 26 时,输入文件就不能表示Z 列以后的路障了。(这句话不用专
门理他。其实就是从A 的ascii 码开始向后顺延,不管是什么字母就行了。)

输出描述 Output Description

输出文件应该只由一行组成,即萨丽能够经过的最多格子数。

样例输入 Sample Input

8 4
E2
A6
G1
F5

样例输出 Sample Output

33

数据范围及提示 Data Size & Hint

(1 < n <= 120)

1 <= B <= 200

 #include<iostream>
using namespace std;
#include<cstdio>
#include<cstring>
#define N 130
bool map[N][N]={false};
bool jz[N][N]={false};
int n,b;
int sum=;
int xx[]={,-,,,};
int yy[]={,,-,,};
void dfs(int x,int y,int dir,int bushu)
{
if(jz[x][y]) return;
sum=max(bushu,sum);
jz[x][y]=true;
int nx=x+xx[dir],ny=y+yy[dir];
if(nx<||nx>n||ny<||ny>n||map[nx][ny])
{
if(dir==||dir==)
{
for(int j=;j<=;++j)
{
int zx=x+xx[j],zy=y+yy[j];
if(!map[zx][zy]&&!jz[zx][zy])
dfs(zx,zy,j,bushu+);
}
}
else {
int zx=x+xx[],zy=y+yy[];
if(!map[zx][zy]&&!jz[zx][zy])
dfs(zx,zy,,bushu+);
zx=x+xx[],zy=y+yy[];
if(!map[zx][zy]&&!jz[zx][zy])
dfs(zx,zy,,bushu+);
}
}
else dfs(nx,ny,dir,bushu+); jz[x][y]=;/*回溯*/
}
void input()
{
scanf("%d%d",&n,&b);
char a1[];
for(int i=;i<=n;++i)
{
map[i][]=map[][i]=map[n+][i]=map[i][n+]=true;
}/*有了这个就不用判断出界了*/
int b1;
for(int i=;i<=b;++i)
{
scanf("\n%c%d",&a1,&b1);/*这个读入的地方写错了,坑了我好久*/
map[a1[]-'A'+][b1]=true;
}
}
int main()
{
input();
for(int i=;i<=;++i)
{
memset(jz,,sizeof(jz));
dfs(,,i,);
}
printf("%d\n",sum);
return ;
}

DFS cdoevs 3100 蜗牛的更多相关文章

  1. [USACO5.2]蜗牛的旅行Snail Trails(有条件的dfs)

    题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总是从棋盘的左上角出发.棋盘上有空的格子(用“.”来表示)和B 个路障 ...

  2. XJOI1571爱心蜗牛【树形动规】

    爱心蜗牛 猫猫把嘴伸进池子里,正准备"吸"鱼吃,却听到门铃响了.猫猫擦了擦脸上的水,打开门一看,那人正是她的好朋友--川川.川川手里拿着一辆玩具汽车,对猫猫说:"这是我的 ...

  3. 洛谷——P1560 [USACO5.2]蜗牛的旅行Snail Trails

    P1560 [USACO5.2]蜗牛的旅行Snail Trails 题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总 ...

  4. 洛谷 P1560 [USACO5.2]蜗牛的旅行Snail Trails(不明原因的scanf错误)

    P1560 [USACO5.2]蜗牛的旅行Snail Trails 题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总 ...

  5. BZOJ 3083: 遥远的国度 [树链剖分 DFS序 LCA]

    3083: 遥远的国度 Time Limit: 10 Sec  Memory Limit: 1280 MBSubmit: 3127  Solved: 795[Submit][Status][Discu ...

  6. BZOJ 1103: [POI2007]大都市meg [DFS序 树状数组]

    1103: [POI2007]大都市meg Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2221  Solved: 1179[Submit][Sta ...

  7. BZOJ 4196: [Noi2015]软件包管理器 [树链剖分 DFS序]

    4196: [Noi2015]软件包管理器 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1352  Solved: 780[Submit][Stat ...

  8. 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)

    图的遍历的定义: 从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次.(连通图与非连通图) 深度优先遍历(DFS): 1.访问指定的起始顶点: 2.若当前访问的顶点的邻接顶点有未被访问的,则 ...

  9. BZOJ 2434: [Noi2011]阿狸的打字机 [AC自动机 Fail树 树状数组 DFS序]

    2434: [Noi2011]阿狸的打字机 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 2545  Solved: 1419[Submit][Sta ...

随机推荐

  1. edittext 监听内容变化

    给EditText追加ChangedListener可以监听EditText内容变化的监听 如图是效果图  类似于过滤的一种实现 1  布局也就是一个EditText,当EditText内容发生变化时 ...

  2. 泛函编程(20)-泛函库设计-Further Into Parallelism

    上两节我们建了一个并行运算组件库,实现了一些基本的并行运算功能.到现在这个阶段,编写并行运算函数已经可以和数学代数解题相近了:我们了解了问题需求,然后从类型匹配入手逐步产生题解.下面我们再多做几个练习 ...

  3. hibernate3 Duplicate class/entity mapping(异常)

    hibernate3 Duplicate class/entity mapping(异常) 代码:      Configuration config = new Configuration().ad ...

  4. 【Asphyre引擎】学习笔记(二)

    转一篇火人论坛那边的一份学习文档,我简单排一下版,希望对入门者有帮助. 感谢China Yang,这份文档也帮助我快速入了门. 和我一起学 Asphyre Sphinx Framework v1.0. ...

  5. Html==>>一些经典

    1.CSS overflow 属性 2.<input>标签 <input> 标签用于搜集用户信息. 1 type属性 根据不同的 type 属性值,输入字段拥有很多种形式.可以 ...

  6. SFTP和FTS协议的区别

    都是为FTP连接加密,协议非常相似.一个是借助SSL协议加密,一个时借助SSH协议加密.SSL是为HTTP/SMTP等加密设计的:SSH是为TELNET/FTP等加密.建立传输通道而设计的.其实SSH ...

  7. HTML 运算符、类型转换

    1.类型转换: 分为自动转换和强制转换,一般用强制转换. 其他类型转换为整数:parseInt(): 其他类型转换为小数:parseFloat(): 判断是否是一个合法的数字类型:isNaN(): 是 ...

  8. C# 如何使用 svcutil.exe 创建 WCF 客户端代码

    工具:svcutil.exe 参数:指定wsdl.输出源码文件.输出配置文件 示例: D:\>svcutil.exe http://localhost:8087/DataService/?wsd ...

  9. ng-show

    //当ng-show="false"时,自动添加 #animate.ng-hide { } #animate.ng-hide-add { } #animate.ng-hide-ad ...

  10. JavaWeb开发必过关-Servlet学习(一)

    一.什么是Servlet servlet其实是一个小程序,它是运行在服务器上的,一个servlet就是一个Java类,可以通过"请求-响应"编程模型来访问这个驻留在服务器内存的Se ...