题目描述 Description

有一个矩形房间,覆盖正方形瓷砖。每块瓷砖涂成了红色或黑色。一名男子站在黑色的瓷砖上,由此出发,可以移到四个相邻瓷砖之一,但他不能移动到红砖上,只能移动到黑砖上。编写一个程序,计算他通过重复上述移动所能经过的黑砖数。

输入描述 Input Description

输入包含多个数据集。一个数据集开头行包含两个正整数W和H,W和H分别表示矩形房间的列数和行数,且都不超过20.
每个数据集有H行,其中每行包含W个字符。每个字符的含义如下所示:
'.'——黑砖
'#'——红砖
'@'——男子(每个数据集仅出现一次)
两个0表示输入结束。

输出描述 Output Description

对每个数据集,程序应该输出一行,包含男子从初始瓷砖出发可到达的瓷砖数。

样例输入 Sample Input

6 9
....#.
.....#
......
......
......
......
......
#@...#
.#..#.
11 9
.#.........
.#.#######.
.#.#.....#.
.#.#.###.#.
.#.#..@#.#.
.#.#####.#.
.#.......#.
.#########.
...........
11 6
..#..#..#..
..#..#..#..
..#..#..###
..#..#..#@.
..#..#..#..
..#..#..#..
7 7
..#.#..
..#.#..
###.###
...@...
###.###
..#.#..
..#.#..
0 0

样例输出 Sample Output

45
59
6
13

裸题 暴搜可过

注意每次数组清空 注意字符读入

//codevs2806 ºìÓëºÚ DFS
//½ñÌìÍíÉϾëÁË Ð´ËÑË÷°É дÉÏÈýµÀ È»ºó¿´¿´ÎÄ»¯¿Î
//copyright by ametake
#include#includeusing namespace std;
const int maxn=20+5;
const int dx[4]={1,0,-1,0};
const int dy[4]={0,1,0,-1};
bool a[maxn][maxn],vis[maxn][maxn];//1ºÚ
int w,h,ans=0;
bool can(int xx,int yy)
{
if (xx<1||xx>h||yy<1||yy>w||!a[xx][yy]||vis[xx][yy]) return false;
return true;
}
void dfs(int xx,int yy)
{
vis[xx][yy]=true;
ans++;
for (int i=0;i<4;i++)
{
xx+=dx[i];
yy+=dy[i];
if (can(xx,yy)) dfs(xx,yy);
xx-=dx[i];
yy-=dy[i];
}
return;
}
int main()
{
freopen("1.txt","r",stdin);
char ch;
int xx,yy;
while(scanf("%d%d",&w,&h)==2&&w)
{
ans=0;
memset(a,0,sizeof(a));
memset(vis,0,sizeof(vis));
scanf("%c",&ch);
for (int i=1;i<=h;i++)
{
for (int j=1;j<=w;j++)
{
scanf("%c",&ch);
if (ch=='.') a[i][j]=1;
else if (ch=='@')
{
xx=i;
yy=j;
}
}
scanf("%c",&ch);
}
dfs(xx,yy);
printf("%d\n",ans);
}
return 0;
}

——尘世难逢开口笑,菊花须插满头归

【基础练习】【DFS】codevs2806 红与黑题解相关推荐

  1. c++ DFS练习 红与黑

    红与黑是DFS的一题经典练习题,比较简单,尽可能自己打出代码 题目原题如下: There is a rectangular room, covered with square tiles. Each ...

  2. 数据结构基础(21) --DFS与BFS

    DFS 从图中某个顶点V0 出发,访问此顶点,然后依次从V0的各个未被访问的邻接点出发深度优先搜索遍历图,直至图中所有和V0有路径相通的顶点都被访问到(使用堆栈). //使用邻接矩阵存储的无向图的深度 ...

  3. 搜素算法(基础)--DFS/BFS算法(JAVA)

    DFS.BFS的定义及C语言算法实现请参照 连通图遍历策略之深度优先搜索(C语言) 连通图遍历策略之广度优先搜索(C语言) 为了便于理解这里的数据是一个无向图,要求输出遍历顺序 下面只给出用例和算法, ...

  4. 【基础练习】codevs1506 传话题解

    题目描述 Description 一个朋友网络,如果a认识b,那么如果a第一次收到某个消息,那么会把这个消息传给b,以及所有a认识的人. 如果a认识b,b不一定认识a. 所有人从1到n编号,给出所有& ...

  5. codeup DFS or BFS?题解

    题目描述如下: 说好了,题目不黑人. 给你一个8*8的矩阵,你的初始位置是左下角方格(用'U'表示),你的目标位置是右上角的方格(用'A'表示),其余的62个方格,如果是'.',表示这个方格为空,如果 ...

  6. 详解ACM基础算法—DFS深度优先搜索算法 HIT杨朔

    深度优先搜索(DFS)是搜索手段之一.是从某个状态开始不断转移状态直到无法转移为止,然后退回到前一步状态继续转移其他状态,可以想象为一个沿树爬行的虫子,在一个交叉口他会首先随机选择一条分岔路口一直走下 ...

  7. 牛客寒假算法基础集训营3 非官方题解

    附官方题解链接 A. 处女座与线性代数 链接:https://ac.nowcoder.com/acm/contest/329/A 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/ ...

  8. 【算法基础】DFS深度优先算法 —— AcWing 843. n-皇后问题 AcWing 842. 排列数字

    目录

  9. 基础博弈论题和一些题解

    1.Brave Game   HDU - 1846 题意:给出n个石子和m,俩人取,每次最多取m个,不能取的输,问输的是谁. 思路:典型巴什博弈,可以发现,如果一共有m+1个物品,我们去取它,先手至少 ...

最新文章

  1. c语言实现 十进制到二进制的转换
  2. Java中的访问控制权限
  3. python多元线性回归模型_python – 使用Tensorflow的多元线性回归模型
  4. java实验报告 05 类与_java程序设计类与方法-java实验报告
  5. 关于SpringAOP的XML方式的配置
  6. c++语句和流程控制
  7. linux安装字体时找不到mkfontscale、mkfontdir
  8. WEB服务器 - Apache、Nnginx、Lighttpd的比较和择优(转)
  9. 一个列表包揽所有你需要的Windows应用
  10. python-元组,列表,字典常用方法
  11. html 5实用特性之data属性
  12. linux 内核源码学习
  13. springboot 对象 空指针_springboot获取getBean方法以及ApplicationContext空指针问题解决...
  14. poj3274 找平衡数列(哈希加一点数学思维)
  15. SCSA之信息安全概述
  16. 存储器管理的内存连续分配方式详解
  17. autojs和按键精灵哪个好?按键精灵打包开始收费了,是弃坑还是继续杠?
  18. matlab get(gcf,'postion ')相关解释
  19. 详述支付网关的设计原则
  20. linux tac命令,Linux tac 命令 command not found tac 命令详解 tac 命令未找到 tac 命令安装 - CommandNotFound ⚡️ 坑否...

热门文章

  1. unity3d环境搭建
  2. python socket send_Python socket.send方法代码示例
  3. Java Taste 记录java带给我们的小滋小味
  4. 10大Android手机杀毒软件
  5. 39.html5的动画(animation)
  6. 信号量机制中的down和up函数
  7. AV3680A天馈线测试仪使用方式
  8. JVM、JDK、JER介绍
  9. antdv tabs闪动
  10. 快递查询(快递单号智能识别/快递公司+快递单号)-完整提供 Demo 代码示例及数据专业且全面的 API 查询接口