nyoj 27-水池数目(BFS, DFS)
27-水池数目
内存限制:64MB
时间限制:3000ms
Special Judge: No
accepted:17
submit:22
题目描述:
输入描述:
第一行输入一个整数N,表示共有N组测试数据
每一组数据都是先输入该地图的行数m(0<m<100)与列数n(0<n<100),然后,输入接下来的m行每行输入n个数,表示此处有水还是没水(1表示此处是水池,0表示此处是地面)
输出描述:
输出该地图中水池的个数。
要注意,每个水池的旁边(上下左右四个位置)如果还是水池的话的话,它们可以看做是同一个水池。
样例输入:
2
3 4
1 0 0 0
0 0 1 1
1 1 1 0
5 5
1 1 1 1 0
0 0 1 0 1
0 0 0 0 0
1 1 1 0 0
0 0 1 1 1
样例输出:
2
3 分析1(BFS):
①、该题即就是看独立的1的堆数有多少
②、根据BFS的思想,将数据为1的每层数据变为0后,向下一层遍历,以递推的思想将每一个1都变为0 步骤:
①、用BFS遍历模板完成数据1的遍历及修改 核心代码:
void bfs(int x, int y)
{
queue<node> Q;
node q1, q2;
q1.a = x, q1.b = y;
Q.push(q1);
while(!Q.empty())
{
q1 = Q.front();
for(int i = ; i <= ; ++ i)
{
q2.a = q1.a + mov[i][];
q2.b = q2.b + mov[i][];
if(!my_map[q2.a][q2.b]) continue;
my_map[q2.a][q2.b] = ;
Q.push(q2);
}
Q.pop();
}
}
C/C++代码实现(AC):
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <stack>
#include <map>
#include <queue> using namespace std;
const int MAXN = ;
int my_map[MAXN][MAXN], book[MAXN][MAXN], mov[][] = {{, }, {, }, {-, }, {, -}};
struct node
{
int a, b;
}; bool judge(node q)
{
if(my_map[q.a][q.b]) return true;
return false;
} void bfs(int x, int y)
{
queue <node> Q;
node q1, q2;
q1.a = x, q1.b = y;
Q.push(q1);
while(!Q.empty())
{
q1 = Q.front();
for(int i = ; i <= ; ++ i)
{
q2.a = q1.a + mov[i][];
q2.b = q1.b + mov[i][];
if(!judge(q2)) continue;
my_map[q2.a][q2.b] = ;
Q.push(q2);
}
Q.pop();
}
} int main()
{
int t;
scanf("%d", &t);
while(t --)
{
int n, m, cnt = ;
memset(book, , sizeof(book));
scanf("%d%d", &n, &m);
for(int i = ; i <= n; ++ i)
for(int j = ; j <= m; ++ j)
scanf("%d", &my_map[i][j]); for(int i = ; i <= n; ++ i)
{
for(int j = ; j <= m; ++ j)
{
if(my_map[i][j])
{
++ cnt;
bfs(i, j);
}
}
}
printf("%d\n", cnt);
}
return ;
}
分析2(DFS):
用DFS只是在处理遍历方式有点不同,dfs是属于一条路走到底的走法
核心代码:
void dfs(int x, int y)
{
if(!my_map[x+mov[i][]][y+mov[i][]]) return ;
for(int i = ; i <= ; ++ i)
{
if(book[x+mov[i][]][y+mov[i][]]) continue;
book[x+mov[i][]][y+mov[i][]] = ;
my_map[x+mov[i][]][y+mov[i][]] = ;
dfs(x+mov[i][], y+mov[i][]);
book[x+mov[i][]][y+mov[i][]] = ;
}
}
C/C++代码实现(AC):
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <stack>
#include <map>
#include <queue> using namespace std;
const int MAXN = ;
int my_map[MAXN][MAXN], book[MAXN][MAXN], mov[][] = {{, }, {, }, {-, }, {, -}};
struct node
{
int a, b;
}; bool judge(node q)
{
if(my_map[q.a][q.b]) return true;
return false;
} void dfs(int x, int y)
{
if(!my_map[x][y]) return;
for(int i = ; i <= ; ++ i)
{
if(book[x+mov[i][]][y+mov[i][]]) continue;
book[x+mov[i][]][y+mov[i][]] = ;
my_map[x][y] = ;
dfs(x+mov[i][], y+mov[i][]);
book[x+mov[i][]][y+mov[i][]] = ;
}
} int main()
{
int t;
scanf("%d", &t);
while(t --)
{
int n, m, cnt = ;
memset(book, , sizeof(book));
scanf("%d%d", &n, &m);
for(int i = ; i <= n; ++ i)
for(int j = ; j <= m; ++ j)
scanf("%d", &my_map[i][j]); for(int i = ; i <= n; ++ i)
{
for(int j = ; j <= m; ++ j)
{
if(my_map[i][j])
{
++ cnt;
dfs(i, j);
}
}
}
printf("%d\n", cnt);
}
return ;
}
nyoj 27-水池数目(BFS, DFS)的更多相关文章
- NYOJ 27.水池数目-DFS求连通块
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
- nyoj 27 水池数目
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
- nyoj27水池数目 (DFS)
题目27 题目信息 执行结果 本题排行 pid=27" style="text-decoration:none; color:rgb(55,119,188)">讨论 ...
- 水池数目(DFS)
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
- NYOJ题目27水池数目
--------------------------------------------- 这道题有点坑,也怪我总是有点马虎,按照正常人的思维0是表示有水池啊竟然是1表示有水池,最坑的是写反了竟然还能 ...
- nyoj水池数目
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
- ACM 水池数目
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
- acm入门搜索-水池数目
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地图上仅标识了此处 ...
- ny27 水池数目
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地图上 ...
随机推荐
- [BZOJ1054] 移动玩具
1054: [HAOI2008]移动玩具 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2741 Solved: 1537[Submit][Stat ...
- opencv::轮廓周围绘制矩形框和圆形框
基于RDP算法实现,目的是减少多边形轮廓点数 approxPolyDP(InputArray curve, OutputArray approxCurve, double epsilon, bool ...
- xml 文件操作
'XML添加 Public Sub Add(ID As String, RFSerialnumber As String, Mood As Integer) If reatch(RFS ...
- 【python数据分析实战】电影票房数据分析(一)数据采集
目录 1.获取url 2.开始采集 3.存入mysql 本文是爬虫及可视化的练习项目,目标是爬取猫眼票房的全部数据并做可视化分析. 1.获取url 我们先打开猫眼票房http://piaofang.m ...
- 卡特兰(Catalan)数入门详解
也许更好的阅读体验 基本概念 介绍 学卡特兰数我觉得可能比组合数要难一点,因为组合数可以很明确的告诉你那个公式是在干什么,而卡特兰数却像是在用大量例子来解释什么时卡特兰数 这里,我对卡特兰数做一点自己 ...
- django测试开发-1.开始Hello django!
用python开发出一个web页面的时候,需要找一个支持python语言的web框架.django框架有丰富的文档和学习资料,也是非常成熟的web开发框架,本篇写一个简单的“hello django! ...
- 树莓派上搭建arduino命令行开发环境
-------------还是博客园上面的格式看这舒服,不去新浪了------------- 为什么要在树莓派上开发arduino呢?总要把树莓派用起来嘛,不然老吃灰. 树莓派使用SSH时没有图形界面 ...
- 你的 Java 并发程序 Bug,100% 是这几个原因造成的
可见性问题 可见性是指一个线程对共享变量进行了修改,其他线程能够立马看到该共享变量更新后的值,这视乎是一个合情合理的要求,但是在多线程的情况下,可能就要让你失望了,由于每个 CPU 都有自己的缓存,每 ...
- 记录一次诡异的Maven Profile不生效的问题
记录一次诡异的Maven Profile不生效的问题 现象 maven 打包之后,复制的 profile对应的resource文件总是不正确的. 即便是加了 mvn clean package -P ...
- Log4j slf4j 配置简单介绍
Log4j slf4j 配置简单介绍 先借鉴一篇很好的文章 为什么要使用SLF4J而不是Log4J import org.slf4j.Logger; import org.slf4j.LoggerFa ...