题目传送门

  需要root权限的传送门

题目大意

  有一个$n\times m$的网格图,每一格都有一个高度。一次降雨过后问最多能积多少水。

  考虑算每一高度能储存的水的量。

  如果小于等于这个高度的格子和边界连通,那么水就会流走,这一部分不能算入答案。

  所以用并查集维护高度小于等于当前高度的格子的连通性。每次答案加已经找到的格子数目减去和边界连通的格子数。

  时间复杂度$O(nm + V)$。(用真·并查集就是这样)

  网上咋一群带个log的做法。想去loj出个加强版。

Code

 /**
* bzoj
* Problem#2936
* Accepted
* Time: 56ms
* Memory: 1688k
*/
#include <bits/stdc++.h>
using namespace std;
typedef bool boolean; const int N = , V = ;
const int mov[][] = {{, }, {, }, {, -}, {-, }}; typedef class Dsu {
public:
int *f;
int *siz; Dsu() { }
Dsu(int n) {
f = new int[(n + )];
siz = new int[(n + )];
f[] = siz[] = ;
for (int i = ; i <= n; i++)
f[i] = i;
for (int i = ; i <= n; i++)
siz[i] = ;
} int find(int x) {
return (f[x] == x) ? (x) :(f[x] = find(f[x]));
} void unit(int x, int y) {
int fx = find(x);
int fy = find(y);
if (fx == fy)
return;
siz[fy] += siz[fx];
f[fx] = fy;
}
}Dsu; int n, m;
Dsu uf;
boolean found[N][N];
vector< pair<int, int> > vs[V + ]; int id(int x, int y) {
if (!x || !y || x == n + || y == m + )
return ;
return (x - ) * m + y;
} inline void init() {
scanf("%d%d", &n, &m);
uf = Dsu(n * m);
for (int i = ; i <= n; i++)
for (int j = , h; j <= m; j++) {
scanf("%d", &h);
vs[h].push_back(pair<int, int>(i, j));
}
} int cfound = , res = ;
inline void solve() {
int all = n * m;
for (int v = ; v <= V && uf.siz[uf.find()] != all; v++) {
for (int j = ; j < (signed) vs[v].size(); j++) {
int x = vs[v][j].first, y = vs[v][j].second;
found[x][y] = true, cfound++;
for (int k = ; k < ; k++) {
int nx = x + mov[k][], ny = y + mov[k][], nxid = id(nx, ny);
if (!nxid || found[nx][ny])
uf.unit(nxid, id(x, y));
}
}
res += cfound - uf.siz[uf.find()];
}
printf("%d", res);
} int main() {
init();
solve();
return ;
}

bzoj 2936 [Poi 1999] 降水 - 并查集的更多相关文章

  1. BZOJ.2054.疯狂的馒头(并查集)

    BZOJ 倒序处理,就是并查集傻题了.. 并查集就是确定下一个未染色位置的,直接跳到那个位置染.然而我越想越麻烦=-= 以为有线性的做法,发现还是要并查集.. 数据随机线段树也能过去. //18400 ...

  2. 2021.08.03 BZOJ 疯狂的馒头(并查集)

    2021.08.03 BZOJ 疯狂的馒头(并查集) 疯狂的馒头 - 题目 - 黑暗爆炸OJ (darkbzoj.tk) 重点: 1.并查集的神奇运用 2.离线化 题意: 给一个长为n的序列,进行m次 ...

  3. BZOJ 4195: [Noi2015]程序自动分析 并查集+离散化

    LUOGU 1955BZOJ 4195 题目描述 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3...代表程序中出现的变量 ...

  4. bzoj 2733 永无乡 - 并查集 - 线段树

    永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通过桥可以从一个岛 到达另一个岛. ...

  5. bzoj 3673&3674 可持久化并查集&加强版(可持久化线段树+启发式合并)

    CCZ在2015年8月25日也就是初三暑假要结束的时候就已经能切这种题了%%% 学习了另一种启发式合并的方法,按秩合并,也就是按树的深度合并,实际上是和按树的大小一个道理,但是感觉(至少在这题上)更好 ...

  6. bzoj 1854 游戏 二分图匹配 || 并查集

    题目链接 Description lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的 ...

  7. Luogu P2391 白雪皑皑 && BZOJ 2054: 疯狂的馒头 并查集

    4月的时候在luogu上做过 白雪皑皑 这道题,当时一遍AC可高兴了qwq,后来去了个厕所,路上忽然发现自己的做法是错的qwq...然后就咕咕了qwq 今天看到了 疯狂的馒头 ,发现一毛一样OvO.. ...

  8. 【BZOJ 3674】可持久化并查集加强版&【BZOJ 3673】可持久化并查集 by zky 用可持久化线段树破之

    最后还是去掉异或顺手A了3673,,, 并查集其实就是fa数组,我们只需要维护这个fa数组,用可持久化线段树就行啦 1:判断是否属于同一集合,我加了路径压缩. 2:直接把跟的值指向root[k]的值破 ...

  9. 【BZOJ】3673: 可持久化并查集 by zky & 3674: 可持久化并查集加强版(可持久化线段树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=3674 http://www.lydsy.com/JudgeOnline/problem.php?id ...

随机推荐

  1. android 流程跟踪

    #记录一下 Thread cur_thread = Thread.currentThread(); StackTraceElement stack[] = cur_thread.getStackTra ...

  2. 增删改(DML)操作

    增删改(DML)操作 1.1事务(transaction) 事务是数据库操作的最小单元,又ACID的特性,应该保证一个事务的sql语句要么同时成功,要么都不成功. Mybatis中配置了事务管理器,t ...

  3. linux 系统 cp: omitting directory 问题解决

    在linux系统中复制文件夹时提示如下: cp: omitting directory `foldera/' 其中foldera是我要复制的文件夹名,出现该警告的原因是因为foldera目录下还存在目 ...

  4. whu 643 Soul Artist(二维BIT 区间更新,单点查询)

    Soul Artis [题目链接]Soul Artis [题目类型]二维BIT &题解: 二维区间更新和一维相比,要容斥一下,更新一块区间就是更新4个点. 还有这个我先是写了2*n^2logn ...

  5. spark sql01

    package sql; import org.apache.spark.SparkConf; import org.apache.spark.api.java.JavaSparkContext; i ...

  6. TP引用样式表和js文件及验证码

    TP引用样式表和js文件及验证码 引入样式表和js文件 <script src="__PUBLIC__/bootstrap/js/jquery-1.11.2.min.js"& ...

  7. 软件常用设置(VC, eclipse ,nodejs)---自己备用

    留存复制使用 1.VC ----1.1VC项目设置 输出目录: $(SolutionDir)../bin/$(platform)/$(Configuration) $(ProjectDir)../bi ...

  8. wordpress练习

    ---恢复内容开始--- wp_options数据表储存网站的一些基本信息 bloginfo()    //输出    bloginfo('stylesheet_url')  //输出style.cs ...

  9. 谈谈CSS中一些比较"偏门"的小知识

    前面我写了:谈谈html中一些比较"偏门"的知识,现在这篇(主要)想谈谈个人所见的CSS一些小知识点,加深印象:同时也希望有需要的人能有收获! 1.常见的浏览器内核: 以IE为代表 ...

  10. 即时通信系统中实现全局系统通知,并与Web后台集成【附C#开源即时通讯系统(支持广域网)——QQ高仿版IM最新源码】

    像QQ这样的即时通信软件,时不时就会从桌面的右下角弹出一个小窗口,或是显示一个广告.或是一个新闻.或是一个公告等.在这里,我们将其统称为“全局系统通知”.很多使用C#开源即时通讯系统——GGTalk的 ...