POJ-1979 深度优先搜索DFS
来源:互联网 发布:网络小黄金骗局 编辑:程序博客网 时间:2024/05/16 18:39
POJ-1979这道题用到的是深度优先搜索(DFS),题目本身很好理解,但是里面有个陷阱啊。。
个人理解:
这道题首先应该在输入时找出(@)所在位置并且从此处开始进行深度优先搜索遍历,在运用DFS时,要注意将已经遍历的点更新为“#”。遍历时从上下左右四个方向进行遍历,直到遇到下一个“.”。具体看代码中的注释。
C++代码:
#include <iostream>#include <cstdio>#define MAX_N 30using namespace std;char field[MAX_N][MAX_N];int n,m;//m行n列 int dx[4] = {1,0,-1,0};int dy[4] = {0,1,0,-1};int ans = 0;int nx,ny;void dfs(int x,int y){if(x>=0 && x <n && y>=0 && y < m && field[x][y] == '.'){//在查找到可以走的点时field[x][y] = '#';//将该出的“.”换位“#”ans++;//并且将结果加一}else{//如果没有找到可以走的点则返回return;}for(int i = 0;i<4;i++){//往四个方向走(1,0)(0,1)(-1,0)(0,-1)nx = x + dx[i];ny = y + dy[i];dfs(nx,ny);}}int main(){int x,y;while((cin>>m>>n) && m != 0){//输入m为零时结束循环。。我呢,在此处犯了一个错误,把n和m搞反了。。测试了好久才找到原因ans = 0;//要注意及时清零,以免影响下一组数据for(int i = 0;i<n;i++){for(int j = 0;j<m;j++){cin>>field[i][j];if(field[i][j] == '@'){ //起点位置,记录下来x = i;y = j;field[i][j] = '.';//因为题目要求其本身也算是一个点}}getchar(); //这里正是陷阱所在!!每一次输完一行时就要按换行符,而换行符也会作为一个符号被读取到field数组中,所以将该换行符吸取掉}dfs(x,y);cout<<ans<<endl;}return 0;}
其中DFS可以换一种写法:
void dfs(int x,int y){field[x][y] = '#';for(int i = 0;i<4;i++){nx = x + dx[i];ny = y + dy[i];if(nx>=0 && nx <n && ny>=0 && ny < m && field[nx][ny] == '.'){ans++;dfs(nx,ny);}}}
阅读全文
0 0
- ACM-POJ 1979 DFS 深度优先搜索
- POJ-1979 深度优先搜索DFS
- poj 1979 深度优先搜索(DFS)算法
- ACM-POJ 1562 DFS 深度优先搜索
- 深度优先搜索dfs(poj 1655)
- 深度优先搜索 DFS
- 深度优先搜索 DFS
- DFS 深度优先搜索
- DFS 深度优先搜索
- 深度优先搜索(DFS)
- 深度优先搜索(DFS)
- 深度优先搜索DFS
- DFS深度优先搜索
- 深度优先搜索(DFS)
- dfs深度优先搜索
- dfs 深度优先搜索
- 深度优先搜索(DFS)
- 深度优先搜索DFS
- 找出兼类词并计算兼类词占整个词表的百分比
- 算法竞赛入门-习题3-9 子序列(All in All, UVa 10340)
- 百度地图的集成
- 五行与四季养生
- 自己实现RPC框架(4)
- POJ-1979 深度优先搜索DFS
- C# 第三方类库使用目录
- ubuntu 16.04 安装 shadowsocks-qt5 并配置 pac 全局代理 转自核果网
- Java中的并发知识点梳理
- Qt之pro配置详解
- java最实用newFixedThreadPool线程池
- Android7.0中文文档(API)--- TabHost
- openstack-network-instances
- django中出现莫名其妙奇妙的错误,发现是python版本的问题