DFS cdoevs 3100 蜗牛
cdoevs 3100 蜗牛
萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120)。
她总是从棋盘的左上角出发。棋盘上有空的格子(用“.”来表示)和B 个路障(用“#”来表示)。萨丽总是垂直(向上或者向下)或水平(向左或者向右)地走。她可以从出发地(总是记
作A1 )向下或者向右走。一旦萨丽选定了一个方向,她就会一直走下去。如果她遇到棋盘
边缘或者路障,她就停下来,并且转过90 度。她不可能离开棋盘,或者走进路障当中。并且,
萨丽从不跨过她已经经过的格子。当她再也不能走的时候,她就停止散步。
萨丽向右走,再向下,向右,向下,然后向左,再向上,最后向右走。这时她遇到了一个
她已经走过的格子,她就停下来了。但是,如果她在F5 格遇到路障后选择另外一条路——向我
们看来是左边的方向转弯,情况就不一样了。
你的任务是计算并输出,如果萨丽聪明地选择她的路线的话,她所能够经过的最多格子数。
输入的第一行包括N —棋盘的大小,和B —路障的数量(1 <= B <= 200)。接下来的
B 行包含着路障的位置信息。下面的样例输入对应着上面的示例棋盘。下面的输出文件表示问
题的解答。注意,当N > 26 时,输入文件就不能表示Z 列以后的路障了。(这句话不用专
门理他。其实就是从A 的ascii 码开始向后顺延,不管是什么字母就行了。)
输出文件应该只由一行组成,即萨丽能够经过的最多格子数。
8 4
E2
A6
G1
F5
33
(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 蜗牛的更多相关文章
- [USACO5.2]蜗牛的旅行Snail Trails(有条件的dfs)
题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总是从棋盘的左上角出发.棋盘上有空的格子(用“.”来表示)和B 个路障 ...
- XJOI1571爱心蜗牛【树形动规】
爱心蜗牛 猫猫把嘴伸进池子里,正准备"吸"鱼吃,却听到门铃响了.猫猫擦了擦脸上的水,打开门一看,那人正是她的好朋友--川川.川川手里拿着一辆玩具汽车,对猫猫说:"这是我的 ...
- 洛谷——P1560 [USACO5.2]蜗牛的旅行Snail Trails
P1560 [USACO5.2]蜗牛的旅行Snail Trails 题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总 ...
- 洛谷 P1560 [USACO5.2]蜗牛的旅行Snail Trails(不明原因的scanf错误)
P1560 [USACO5.2]蜗牛的旅行Snail Trails 题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总 ...
- BZOJ 3083: 遥远的国度 [树链剖分 DFS序 LCA]
3083: 遥远的国度 Time Limit: 10 Sec Memory Limit: 1280 MBSubmit: 3127 Solved: 795[Submit][Status][Discu ...
- BZOJ 1103: [POI2007]大都市meg [DFS序 树状数组]
1103: [POI2007]大都市meg Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2221 Solved: 1179[Submit][Sta ...
- BZOJ 4196: [Noi2015]软件包管理器 [树链剖分 DFS序]
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1352 Solved: 780[Submit][Stat ...
- 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)
图的遍历的定义: 从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次.(连通图与非连通图) 深度优先遍历(DFS): 1.访问指定的起始顶点: 2.若当前访问的顶点的邻接顶点有未被访问的,则 ...
- BZOJ 2434: [Noi2011]阿狸的打字机 [AC自动机 Fail树 树状数组 DFS序]
2434: [Noi2011]阿狸的打字机 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 2545 Solved: 1419[Submit][Sta ...
随机推荐
- unity3d拓展编辑器Editor的使用
Editor可以拓展Inspector窗口 可以通过代码自己绘制监测面板 先来看一个效果:
- DWR的Reverse Ajax技术实现
DWR的逆向ajax其实主要包括两种模式:主动模式和被动模式.其中主动模式包括Polling和Comet两种,被动模式只有Piggyback这一种. 所谓的Piggyback指的是如果后台有什么内容需 ...
- Play 可以做的 5 件很酷的事
Play 可以做的 5 件很酷的事 本章译者:@Playframwork 通过 5 个实例,透视 Play 框架背后的哲学. 绑定 HTTP 参数到 JAVA 方法参数 用 Play 框架,在 Jav ...
- IOS网络编程之请求内容
资料均来自互联网,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任. 人魔七七:http://www.cnblogs.com/qiqibo/ 一个http请求只要由三 ...
- React入门--------组件API
setState 参数:nextState(object),[callback(function)] 设置nextState的某个键值.通常如果希望在某个事件或某个回调中来重新渲染组件,setStat ...
- 初学Node(六)搭建一个简单的服务器
搭建一个简单的服务器 通过下面的代码可以搭建一个简单的服务器: var http = require("http"); http.createServer(function(req ...
- jquery对javascript事件的封装一览
描述 jquery javascript 鼠标点击某个对象 click() onclick 鼠标双击某个对象 dblclick() ondblclick 元素获得焦点 focus() onfocus ...
- 读书笔记2014第3本:Visual Studio程序员箴言
Visual Studio 2010是我经常使用的程序开发工具,也知道VS中有大量的快捷键可以帮助提高效率,可惜就是不愿意记忆,最近在学vim的时候快速把<Visual Studio程序员箴言& ...
- Python: 关于nose
1. 使用rednose增强输出 pip install rednose nosetests --rednose tests 2. 使用coverage pip install coverage no ...
- Android-AsyncTask异步任务(获取手机联系人)
本篇随笔将讲解一下Android的多线程的知识,以及如何通过AsyncTask机制来实现线程之间的通信. 一.Android当中的多线程 在Android当中,当一个应用程序的组件启动的时候,并且没有 ...