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. MySQL预处理语句

    预制语句的SQL语法基于三个SQL语句: PREPARE stmt_name FROM preparable_stmt; EXECUTE stmt_name [USING @var_name [, @ ...

  2. Qt 框架 开发HTTP 服务器 开发记录

    最近需求需要开发一款 HTTP ,然后由于先前接触过Qt,就直接用Qt写HTTP服务器了,也是为了当作练手,要不然是直接上HTTP框架的. 后端用C++ Qt框架 前端为了练手 当然是纯生的 js h ...

  3. java注释指导手册

    译文出处: Toien Liu   原文出处:Dani Buiza 编者的话:注解是java的一个主要特性且每个java开发者都应该知道如何使用它. 我们已经在Java Code Geeks提供了丰富 ...

  4. hibernate4整合spring3事务问题

    本文是作者在对hibernate4+spring3+struts2整合中遇到的一个问题.对s2sh进行了基本的整合搭建以后,就是对事务的控制管理,将hibernate的事务交由spring管理.根据网 ...

  5. Linux Shell系列教程之(十五) Shell函数简介

    本文是Linux Shell系列教程的第(十五)篇,更多Linux Shell教程请看:Linux Shell系列教程 函数可以将一个复杂功能划分成若干模块,从而使程序结构更加清晰,代码重复利用率更高 ...

  6. 功放AUX接口解析

    功放上的AUX输入端口就是音频输入端口,用来连接音频输出设备:PC机上声卡.MP3播放器.CD机等

  7. Windows工作集内存

    Windows任务管理器默认情况下,“内存(私人工作集)”列处于选中状态. 私人工作集是工作集的一个子集,它是描述每个进程所使用的内存数量的技术术语.私人工作集专门描述了某个进程正在使用的且无法与其他 ...

  8. lambda 个人学习理解

    lambda是简化代码量的写用更简单的方法来写匿名方法 lambda左边是参数,右边是代码块(方法执行语句). 整体运算结果是根据左边参数,执行右边语句,返回右边执行的结果: 匿名方法是简化方法 1. ...

  9. ASP.NET MVC中将控制器分离到类库的实现

    前言 在ASP.NET MVC的开发中,我们创建完项目之后,ASP.NET MVC是已Model-Controller-View的形式存在的,在创建项目自动生成的内容上Model我们很容易分离成类库, ...

  10. asp.net mvc Html.BeginForm()方法

    Html.BeginForm()方法将会输出<form>标签,而且必须以using包起来,如此便可在using程序代码最后退出时,让asp.net mvc帮你补上<form>标 ...