Time Limit: 1 second

Memory Limit: 128 MB

【问题描述】

全球气候变暖,小镇A面临水灾。于是你必须买一些泵把水抽走。泵的抽水能力可以认为是无穷大,但你必须把泵放在合适的位置

,从而能使所有的水能流到泵里。小镇可以认为是N * M的矩阵。矩阵里的每个单元格都是一个‘a’- ‘z’小写字母,该小写

字母表示该格子的高度,字母大的表示该单元格比较高,反之,表示该格子高度比较低。当前单元格的水可以流到上、下、左、

右四个格子,但必须满足这些格子的高度是小于或者等于当前格子的高度。现在,给你一些N * M的矩阵,你至少要买多少个泵

,才能把所有格子的水都能被抽走?

【输入格式】

多组测试数据。

第一行:K,表示有K组测试数据。 1 <= K <= 5.

接下来有K组测试数据,每组测试数据格式如下:

第一行:两个正数, N , M . 1 <= N, M <= 50,表示小镇的大小。

接下来有N行,每行有M个小写字母,表示小镇的地图。

【输出格式】

共K行,每行对应一组数据。至少要买多少个泵,才能把所有格子的水都能抽走。

Sample Input

2

5 5

ccccc

cbbbc

cbabc

cbbbc

ccccc

4 9

cbabcbabc

cbabcbabc

cbabcbabc

cbabcbabc

Sample Output

1

2

Sample Input2

1

11 11

ccccccccccc

caaaaaaaaac

caaaaaaaaac

caazpppzaac

caapdddpaac

caapdddpaac

caapdddpaac

caazpppzaac

caaaaaaaaac

caaaaaaaaac

ccccccccccc

Sample Output2

2

【题目链接】:http://noi.qz5z.com/viewtask.asp?id=t048

【题解】



从最低点开始bfs,看它能到哪些位置;(水泵的位置放在最低点显然更优);

每次都从没有被覆盖过的部分里面找一个最低点进行bfs;

因为高度从’a’->’z’,所以枚举起点的高度为’a’->’z’即可;

遇到一个符合要求的起点就递增答案;



【完整代码】

#include <cstdio>
#include <cstring>
#include <iostream>
#include <queue> using namespace std; const int MAXN = 55;
const int dx[5] = {0,1,-1,0,0};
const int dy[5] = {0,0,0,1,-1}; int n,m;
int dt[MAXN][MAXN];
bool bo[MAXN][MAXN];
queue <pair<int,int> > dl; int main()
{
//freopen("D:\\rush.txt","r",stdin);
int T;
cin >> T;
while (T--)
{
memset(bo,false,sizeof(bo));
cin >> n >> m;
for (int i = 1;i <= n;i++)
{
string s;
cin >> s;
for (int j = 0;j <=m-1;j++)
{
dt[i][j+1] = s[j]-'a';
bo[i][j+1] = true;
}
}
int ans = 0;
for (int mi = 0;mi <= 25;mi++)
for (int i = 1;i <= n;i++)
for (int j = 1;j <= m;j++)
if (dt[i][j] == mi&& bo[i][j])
{
ans++;
bo[i][j] = false;
dl.push(make_pair(i,j));
while (!dl.empty())
{
int x = dl.front().first,y = dl.front().second;
dl.pop();
for (int p=1;p <= 4;p++)
{
int tx = x+dx[p],ty =y+dy[p];
if (bo[tx][ty]&&dt[tx][ty]>=dt[x][y])
{
bo[tx][ty] = false;
dl.push(make_pair(tx,ty));
}
}
}
}
cout << ans << endl;
}
return 0;
}

【t048】水流的更多相关文章

  1. BZOJ3396: [Usaco2009 Jan]Total flow 水流

    3396: [Usaco2009 Jan]Total flow 水流 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 45  Solved: 27[Sub ...

  2. Android自定义控件实战——水流波动效果的实现WaveView

    转载请声明出处http://blog.csdn.net/zhongkejingwang/article/details/38556891 水流波动的波形都是三角波,曲线是正余弦曲线,但是Android ...

  3. 水流(water)

    水流(water) 题目描述 全球气候变暖,小镇A面临水灾,于是你必须买一些泵把水抽走.泵的抽水能力可以认为是无穷大,但你必须把泵放在合适的位置,从而能使所有的水能流到泵里.小镇可以认为是N×M的矩阵 ...

  4. 3396: [Usaco2009 Jan]Total flow 水流

    3396: [Usaco2009 Jan]Total flow 水流 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 179  Solved: 73[Su ...

  5. [Swift]LeetCode417. 太平洋大西洋水流问题 | Pacific Atlantic Water Flow

    Given an m x n matrix of non-negative integers representing the height of each unit cell in a contin ...

  6. ArcGIS基于DEM计算水流方向的方法(D8算法)

    ArcGIS采用D8算法计算水流方向(9.3.1后新增),输入数据应首先完成了洼地填充处理: One of the keys to deriving hydrologic characteristic ...

  7. 水流(water)(BFS)(DFS)

    水流(water) 时间限制: 1 Sec  内存限制: 64 MB提交: 9  解决: 2[提交][状态][讨论版] 题目描述 全球气候变暖,小镇A面临水灾,于是你必须买一些泵把水抽走.泵的抽水能力 ...

  8. Leetcode 417.太平洋大西洋水流问题

    太平洋大西洋水流问题 给定一个 m x n 的非负整数矩阵来表示一片大陆上各个单元格的高度."太平洋"处于大陆的左边界和上边界,而"大西洋"处于大陆的右边界和下 ...

  9. Unity Shader 2D水流效果

    水流的模拟主要运用了顶点变换和纹理动画的结合: 顶点变换中,利用正弦函数模拟河流的大致形态,例如波长,振幅等. 纹理动画中,将纹理坐标朝某一方向持续滚动以形成流动的效果. 脚本如下: Shader & ...

随机推荐

  1. Hadoop作业性能指标及參数调优实例 (二)Hadoop作业性能调优7个建议

    作者:Shu, Alison Hadoop作业性能调优的两种场景: 一.用户观察到作业性能差,主动寻求帮助. (一)eBayEagle作业性能分析器 1. Hadoop作业性能异常指标 2. Hado ...

  2. golang sync.Once

    package main import ( "fmt" "sync" "time" ) func main() { var once syn ...

  3. POJ 1738 An old Stone Game(石子合并 经典)

    An old Stone Game Time Limit: 5000MS   Memory Limit: 30000K Total Submissions: 3672   Accepted: 1035 ...

  4. 洛谷——U10783 名字被和谐了

    https://www.luogu.org/problem/show?pid=U10783 题目背景 众所周知,我们称g是a的约数,当且仅当g是正数且a mod g = 0. 众所周知,若g既是a的约 ...

  5. hdu4605Magic Ball Game 树状数组

    //给一棵树.树的每个节点的子节点个数是0或2 //对于每个节点都有一个权值w[i] //一个权值为x的球在每个节点的情况有 //x=w[i] 这个球在该点不向下掉 //x<w[i] 这个球往左 ...

  6. svd 奇异值分解

    参考:http://www.cnblogs.com/pinard/p/6251584.html 酉矩阵,关于矩阵的问题,还是很复杂的. 只有方阵才可以进行特征值分解, 但是如果行不等于列,即不是方阵, ...

  7. Excel数据比对-批量数据比对

    1.导出现场的Excel收费规则2.有专门的代码写的测试收费规则的工具(开发自己开发的)3.在这个工具上选择,导出的收费规则Excel,点击导出按钮(导出按钮里面有计算每一列的计费结果4.Excel里 ...

  8. 原生js大总结五

    041.在js中如何用方法将10进制的字符转换成16进制和8进制   数字.toString(16) 数字.toString(8)     042.如何创建时间对象   new Date()   04 ...

  9. CodeVs——T 3305 水果姐逛水果街Ⅱ

    http://codevs.cn/problem/3305/  时间限制: 2 s  空间限制: 256000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 De ...

  10. 洛谷——P1021 邮票面值设计

    https://www.luogu.org/problem/show?pid=1021 题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都 ...