acm入门搜索-水池数目
水池数目
- 描述
 - 校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地图上仅标识了此处是否是水池,现在,你的任务来了,请用计算机算出该地图中共有几个水池。
- 输入
 - 第一行输入一个整数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
#include<iostream> using namespace std; int dir[4][2]={{-1,0},{1,0},{0,1},{0,-1}}; int grid[101][101]; int m,n; void dfs(int x,int y) { int i,newx,newy; grid[x][y]=0; for(i=0;i<4;i++) { newx=x+dir[i][0]; newy=y+dir[i][1]; if(newx<0||newy<0||x>m||newy>n) continue; if(grid[newx][newy]==1) dfs(newx,newy); } } int main() { int T,i,j,count; cin>>T; while(T--) { cin>>m>>n; for(i=0;i<n;i++) { for(j=0;j<m;j++) { cin>>grid[i][j]; } } count=0; for(i=0;i<n;i++) { for(j=0;j<m;j++) { if(grid[i][j]==1) { dfs(i,j); count++; } } } cout<<count<<endl; } } 
 
acm入门搜索-水池数目的更多相关文章
- acm入门搜索-石油数目
		
题意:给出一个N*M的矩形区域和每个区域的状态--有/没有石油,(定义)如果两个有石油的区域是相邻的(水平.垂直.斜)则认为这是属于同一个oil pocket. 求这块矩形区域一共有多少oilpock ...
 - NYOJ27水池数目,类似于FZU1008最大黑区域,简单搜索题~~~
		
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地图上 ...
 - ACM 水池数目
		
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
 - nyoj 27 水池数目
		
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
 - 水池数目(DFS)
		
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
 - nyoj水池数目
		
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
 - NYOJ36 水池数目
		
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
 - HDU 1312 Red and Black --- 入门搜索 BFS解法
		
HDU 1312 题目大意: 一个地图里面有三种元素,分别为"@",".","#",其中@为人的起始位置,"#"可以想象 ...
 - HDU 1312 Red and Black --- 入门搜索 DFS解法
		
HDU 1312 题目大意: 一个地图里面有三种元素,分别为"@",".","#",其中@为人的起始位置,"#"可以想象 ...
 
随机推荐
- [BZOJ]1017 魔兽地图DotR(JSOI2008)
			
BZOJ第一页做着做着就能碰到毒题,做到BZOJ1082小C就忍了,没想到下一题就是这种东西.这种题目不拖出来枭首示众怎么对得起小C流逝的青春啊. Description DotR (Defense ...
 - [BZOJ]3110 K大数查询(ZJOI2013)
			
这大概是唯一一道小C重写了4次的题目. 姿势不对的树套树(Fail) → 分块(Fail) → 整体二分(Succeed) → 树套树(Succeed). 让小C写点心得静静. Description ...
 - POJ2187Beauty Contest 旋转卡壳
			
题目链接 http://poj.org/problem?id=2187 先求凸包 再求凸多边形直径 旋转卡壳模板题 #include<cstdio> #include<cstring ...
 - bzoj2500幸福的道路 树形dp+单调队列
			
2500: 幸福的道路 Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 434 Solved: 170[Submit][Status][Discuss ...
 - YOLO2:实时目标检测视频教程,视频演示, Android Demo ,开源教学项目,论文。
			
实时目标检测和分类 GIF 图: 视频截图: 论文: https://arxiv.org/pdf/1506.02640.pdf https://arxiv.org/pdf/1612.08242.pdf ...
 - PTA 邻接表存储图的广度优先遍历(20 分)
			
6-2 邻接表存储图的广度优先遍历(20 分) 试实现邻接表存储图的广度优先遍历. 函数接口定义: void BFS ( LGraph Graph, Vertex S, void (*Visit)(V ...
 - 了解ASCII、gb系列、Unicode、UTF-8的区别
			
转自:http://www.douban.com/note/334994123/?type=rec ● 为什么有这么多编码? ● UTF-8和GB2312有什么区别? ● 我们在国内做网站是用UTF- ...
 - ubuntu15.10 安装 virtualbox5.0
			
首先安装依赖包.ubuntu15.01安装的时候会出现这个错误: virtualbox-); however: Package libvpx1 is not installed 而且sudo apt- ...
 - vue+node.js+webpack开发微信公众号功能填坑——v -for循环
			
页面整体框架实现,实现小功能,循环出数据,整体代码是上一篇 vue+node.js+webpack开发微信公众号功能填坑--组件按需引入 修改部门代码 app.vue <yd-flexbox&g ...
 - String字符串的操作
			
字符串的常用操作 # Author:nadech name = "my name is nadech" print(name.count("a")) print ...