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 ...
随机推荐
- [转]基于 Quercus 的手游项目终于上线了
原文:http://blog.andsky.com/quercus-php-ngame/ 经过半年的开发,我们第一款手游戏终于开发完毕,架构使用了 netty + Quercus 实现用 php 通过 ...
- 后缀数组---Milk Patterns
POJ 3261 Description Farmer John has noticed that the quality of milk given by his cows varies from ...
- 关于antlr包删除问题
在建这个网站,用户登录的时候,涉及查询问题,然后就出现了java.lang.NoSuchMethodError: antlr.collections.AST.getLine()I错误,我一脸蒙逼,后来 ...
- 【Android】开源项目UI控件分类汇总之Dialog
接前文ProgressBar:Android开发的宝库越来越多,我开发中有需要的组件,主要参考Trinea的大作Android开源项目分类汇总(包含了后面的绝大多数).CSDN上直接拿来用!最火的An ...
- Git的安装和使用记录
Git是目前世界上最先进的分布式版本控制系统(没有之一),只用过集中式版本控制工具的我,今天也要开始学习啦.廖雪峰的git教程我觉得很详细了,这里记录一下步骤以及我终于学会用Markdown了,真的是 ...
- 利用ng-click、ng-switch和click-class制作切换的tabl
效果如下图,当分别点击1,2,3时,下面的不同颜色的div会切换 <html ng-app> <head> <title></title> <sc ...
- CSS重置样式表
网页设计,让人最头疼的莫过于让页面兼容各大浏览器,准确些是兼容它们“默认”的CSS样式表.第一种方式 * {margin:0px; padding:0px;} 这行代码虽然简单,但却让网页解析太慢.于 ...
- NLog 自定义字段 写入 oracle
1.通过Nuget安装NLog 下载,简单入门 请参照 我刚才转的几篇文章,下面我直接贴代码 2.建表语句 create table TBL_LOG ( id ) not null, appname ...
- [Android]编译错误:Could not get unknown property 'release' for SigningConfig container
使用Gradle进行安卓编译时,出现如下错误: Could not get unknown property 'release' for SigningConfig container. 原因: 在主 ...
- Python基础(2)--对象类型
Python使用对象模型来存储数据.构造任何类型的值都是一个对象 所有的Python对象都拥有三个特性:身份.类型.值 身份: 每一个对象都有一个唯一的身份来标志自己,任何对象的身份可以使用内建函数i ...