【基础练习】【DFS】codevs2806 红与黑题解
有一个矩形房间,覆盖正方形瓷砖。每块瓷砖涂成了红色或黑色。一名男子站在黑色的瓷砖上,由此出发,可以移到四个相邻瓷砖之一,但他不能移动到红砖上,只能移动到黑砖上。编写一个程序,计算他通过重复上述移动所能经过的黑砖数。
输入包含多个数据集。一个数据集开头行包含两个正整数W和H,W和H分别表示矩形房间的列数和行数,且都不超过20.
每个数据集有H行,其中每行包含W个字符。每个字符的含义如下所示:
'.'——黑砖
'#'——红砖
'@'——男子(每个数据集仅出现一次)
两个0表示输入结束。
对每个数据集,程序应该输出一行,包含男子从初始瓷砖出发可到达的瓷砖数。
6 9
....#.
.....#
......
......
......
......
......
#@...#
.#..#.
11 9
.#.........
.#.#######.
.#.#.....#.
.#.#.###.#.
.#.#..@#.#.
.#.#####.#.
.#.......#.
.#########.
...........
11 6
..#..#..#..
..#..#..#..
..#..#..###
..#..#..#@.
..#..#..#..
..#..#..#..
7 7
..#.#..
..#.#..
###.###
...@...
###.###
..#.#..
..#.#..
0 0
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 红与黑题解相关推荐
- c++ DFS练习 红与黑
红与黑是DFS的一题经典练习题,比较简单,尽可能自己打出代码 题目原题如下: There is a rectangular room, covered with square tiles. Each ...
- 数据结构基础(21) --DFS与BFS
DFS 从图中某个顶点V0 出发,访问此顶点,然后依次从V0的各个未被访问的邻接点出发深度优先搜索遍历图,直至图中所有和V0有路径相通的顶点都被访问到(使用堆栈). //使用邻接矩阵存储的无向图的深度 ...
- 搜素算法(基础)--DFS/BFS算法(JAVA)
DFS.BFS的定义及C语言算法实现请参照 连通图遍历策略之深度优先搜索(C语言) 连通图遍历策略之广度优先搜索(C语言) 为了便于理解这里的数据是一个无向图,要求输出遍历顺序 下面只给出用例和算法, ...
- 【基础练习】codevs1506 传话题解
题目描述 Description 一个朋友网络,如果a认识b,那么如果a第一次收到某个消息,那么会把这个消息传给b,以及所有a认识的人. 如果a认识b,b不一定认识a. 所有人从1到n编号,给出所有& ...
- codeup DFS or BFS?题解
题目描述如下: 说好了,题目不黑人. 给你一个8*8的矩阵,你的初始位置是左下角方格(用'U'表示),你的目标位置是右上角的方格(用'A'表示),其余的62个方格,如果是'.',表示这个方格为空,如果 ...
- 详解ACM基础算法—DFS深度优先搜索算法 HIT杨朔
深度优先搜索(DFS)是搜索手段之一.是从某个状态开始不断转移状态直到无法转移为止,然后退回到前一步状态继续转移其他状态,可以想象为一个沿树爬行的虫子,在一个交叉口他会首先随机选择一条分岔路口一直走下 ...
- 牛客寒假算法基础集训营3 非官方题解
附官方题解链接 A. 处女座与线性代数 链接:https://ac.nowcoder.com/acm/contest/329/A 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/ ...
- 【算法基础】DFS深度优先算法 —— AcWing 843. n-皇后问题 AcWing 842. 排列数字
目录
- 基础博弈论题和一些题解
1.Brave Game HDU - 1846 题意:给出n个石子和m,俩人取,每次最多取m个,不能取的输,问输的是谁. 思路:典型巴什博弈,可以发现,如果一共有m+1个物品,我们去取它,先手至少 ...
最新文章
- c语言实现 十进制到二进制的转换
- Java中的访问控制权限
- python多元线性回归模型_python – 使用Tensorflow的多元线性回归模型
- java实验报告 05 类与_java程序设计类与方法-java实验报告
- 关于SpringAOP的XML方式的配置
- c++语句和流程控制
- linux安装字体时找不到mkfontscale、mkfontdir
- WEB服务器 - Apache、Nnginx、Lighttpd的比较和择优(转)
- 一个列表包揽所有你需要的Windows应用
- python-元组,列表,字典常用方法
- html 5实用特性之data属性
- linux 内核源码学习
- springboot 对象 空指针_springboot获取getBean方法以及ApplicationContext空指针问题解决...
- poj3274 找平衡数列(哈希加一点数学思维)
- SCSA之信息安全概述
- 存储器管理的内存连续分配方式详解
- autojs和按键精灵哪个好?按键精灵打包开始收费了,是弃坑还是继续杠?
- matlab get(gcf,'postion ')相关解释
- 详述支付网关的设计原则
- linux tac命令,Linux tac 命令 command not found tac 命令详解 tac 命令未找到 tac 命令安装 - CommandNotFound ⚡️ 坑否...