[BZOJ3712]Fiolki 重构树(并查集)
3712: [PA2014]Fiolki
Time Limit: 30 Sec Memory Limit: 128 MB
Description
化学家吉丽想要配置一种神奇的药水来拯救世界。
吉丽有n种不同的液体物质,和n个药瓶(均从1到n编号)。初始时,第i个瓶内装着g[i]克的第i种物质。吉丽需要执行一定的步骤来配置药水,第i个步骤是将第a[i]个瓶子内的所有液体倒入第b[i]个瓶子,此后第a[i]个瓶子不会再被用到。瓶子的容量可以视作是无限的。
吉丽知道某几对液体物质在一起时会发生反应产生沉淀,具体反应是1克c[i]物质和1克d[i]物质生成2克沉淀,一直进行直到某一反应物耗尽。生成的沉淀不会和任何物质反应。当有多于一对可以发生反应的物质在一起时,吉丽知道它们的反应顺序。每次倾倒完后,吉丽会等到反应结束后再执行下一步骤。
吉丽想知道配置过程中总共产生多少沉淀。
Input
第一行三个整数n,m,k(0<=m<n<=200000,0<=k<=500000),分别表示药瓶的个数(即物质的种数),操作步数,可以发生的反应数量。
第二行有n个整数g[1],g[2],…,g[n](1<=g[i]<=10^9),表示初始时每个瓶内物质的质量。
接下来m行,每行两个整数a[i],b[i](1<=a[i],b[i]<=n,a[i]≠b[i]),表示第i个步骤。保证a[i]在以后的步骤中不再出现。
接下来k行,每行是一对可以发生反应的物质c[i],d[i](1<=c[i],d[i]<=n,c[i]≠d[i]),按照反应的优先顺序给出。同一个反应不会重复出现。
Output
Sample Input
2 3 4
1 2
3 2
2 3
Sample Output
此后第a[i]个瓶子不会再被用到.
对于每一对可以反应的物质,他们可能,也只可能在他们重构树上lca处反应
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std;
const int N=,K=;
typedef long long LL;
LL sum;
int n,m,k,w[N],fa[N<<],bin[];
int e,adj[N<<],cnt,f[N<<][],deep[N<<];
int find(int a){return fa[a]==a?a:fa[a]=find(fa[a]);}
inline int min(int a,int b){return a<b?a:b;}
struct data{int a,b;data(int x=,int y=){a=x,b=y;}}step[N];
struct edge{int zhong,next;}s[N<<];
vector<data>re[N<<];
inline void add(int qi,int zhong)
{s[++e].zhong=zhong;s[e].next=adj[qi];adj[qi]=e;}
void dfs(int rt)
{
deep[rt]=deep[f[rt][]]+;
for(int i=adj[rt];i;i=s[i].next)
dfs(s[i].zhong);
}
inline void ST()
{
for(int i=;i<=;i++)
for(int j=;j<=cnt;j++)
f[j][i]=f[f[j][i-]][i-];
}
inline int LCA(int a,int b)
{
if(deep[a]<deep[b])swap(a,b);
int cha=deep[a]-deep[b];
for(int j=;~j;j--)
if(cha&bin[j])a=f[a][j];
if(a==b)return a;
for(int j=;~j;j--)
if(f[a][j]!=f[b][j])a=f[a][j],b=f[b][j];
return f[a][];
}
int main()
{
bin[]=;for(int i=;i<=;i++)bin[i]=bin[i-]<<;
int a,b,lca;scanf("%d%d%d",&n,&m,&k);cnt=n;
for(int i=;i<=n+m;i++)fa[i]=i;
for(int i=;i<=n;i++)scanf("%d",&w[i]);
for(int i=;i<=m;i++)
scanf("%d%d",&step[i].a,&step[i].b),
a=find(step[i].a),b=find(step[i].b),
fa[a]=fa[b]=f[a][]=f[b][]=++cnt,
add(cnt,a),add(cnt,b);
ST();
for(int i=;i<=cnt;i++)
if(!deep[i])dfs(find(i));
for(int i=;i<=k;i++)
{
scanf("%d%d",&a,&b);
if(find(a)==find(b))
lca=LCA(a,b),re[lca].push_back(data(a,b));
}
for(int i=n+;i<=cnt;i++)
for(int j=,len=re[i].size();j<len;j++)
a=min(w[re[i][j].a],w[re[i][j].b]),
w[re[i][j].a]-=a,w[re[i][j].b]-=a,sum+=a;
printf("%lld\n",sum<<);
}
[BZOJ3712]Fiolki 重构树(并查集)的更多相关文章
- [学习笔记]kruskal重构树 && 并查集重构树
		Kruskal 重构树 [您有新的未分配科技点][BZOJ3545&BZOJ3551]克鲁斯卡尔重构树 kruskal是一个性质优秀的算法 加入的边是越来越劣的 科学家们借这个特点尝试搞一点事 ... 
- CF1253F Cheap Robot(神奇思路,图论,最短路,最小生成树/Kruskal 重构树/并查集)
		神仙题. 先考虑平方级别的暴力怎么做. 明显答案有单调性,先二分 \(c\). 先最短路预处理 \(dis_u\) 表示 \(u\) 到离它最近的充电站的距离(一开始把 \(1\) 到 \(k\) 全 ... 
- 【BZOJ3712】Fiolki(并查集重构树)
		[BZOJ3712]Fiolki(并查集重构树) 题面 BZOJ 题解 很神仙的题目. 我们发现所有的合并关系构成了一棵树. 那么两种不同的东西如果产生反应,一定在两个联通块恰好联通的时候反应. 那么 ... 
- BZOJ3712[PA2014]Fiolki——并查集重构树
		题目描述 化学家吉丽想要配置一种神奇的药水来拯救世界.吉丽有n种不同的液体物质,和n个药瓶(均从1到n编号).初始时,第i个瓶内装着g[i]克的第i种物质.吉丽需要执行一定的步骤来配置药水,第i个步骤 ... 
- NOI2018Day1T1 归程 并查集 kruskal kruskal重构树 倍增表 Dijkstra
		原文链接https://www.cnblogs.com/zhouzhendong/p/NOI2018Day1T1.html 题目传送门 - 洛谷P4768 题意 给定一个无向连通图,有 $n$ 个点 ... 
- [NOI2018]归程(可持久化并查集,Kruskal重构树)
		解法一: 1.首先想到离线做法:将边和询问从大到小排序,并查集维护连通块以及每个连通块中所有点到1号点的最短距离.$O(n\log n)$ 配合暴力等可以拿到75分. 2.很容易想到在线做法,使用可持 ... 
- [HDU 3712] Fiolki (带边权并查集+启发式合并)
		[HDU 3712] Fiolki (带边权并查集+启发式合并) 题面 化学家吉丽想要配置一种神奇的药水来拯救世界. 吉丽有n种不同的液体物质,和n个药瓶(均从1到n编号).初始时,第i个瓶内装着g[ ... 
- [bzoj3123][sdoi2013森林] (树上主席树+lca+并查集启发式合并+暴力重构森林)
		Description Input 第一行包含一个正整数testcase,表示当前测试数据的测试点编号.保证1≤testcase≤20. 第二行包含三个整数N,M,T,分别表示节点数.初始边数.操作数 ... 
- 【BZOJ-3545&3551】Peaks&加强版     Kruskal重构树 + 主席树 + DFS序 + 倍增
		3545: [ONTAK2010]Peaks Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1202 Solved: 321[Submit][Sta ... 
随机推荐
- Youtube高清视频下载的3种方法
			经常看视频的朋友都听说或使用过youtube, 它是一个综合性的视频网站,包含的内容多种多样,能满足不同的人的需求,最要的是广告少,资源良心,不像有些网站,动不动就是1分种以上的长广告.有些因为工作 ... 
- 笔试题——C++开发简单记录错误模块
			题目:链接:https://www.nowcoder.com/questionTerminal/67df1d7889cf4c529576383c2e647c48 来源:牛客网 解析及代码来源:http ... 
- 入门向:南邮CTF_ReadAsm2_WP
			题目链接:http://ctf.nuptzj.cn/challenges#ReadAsm2 我比较菜,所以把思路全部敲上来了. 题目很明确告诉我们,这道题考察阅读汇编代码的能力. 在对编译环境和调用约 ... 
- Acer 4750G安装OS X 10.9 DP4(简版)
			一.下载os x 10.9懒人版:http://bbs.pcbeta.com/viewthread-1384504-1-1.html 二.用系统自带的磁盘分区工具划分一个5G左右的临时安装盘(新建分区 ... 
- 搭建gitpage博客
			http://blog.csdn.net/jzooo/article/details/46781805 
- 关于php的array_diff和array_diff_assoc的使用总结
			关于php的array_diff和array_diff_assoc的使用总结 2015-11-07 17:01 184人阅读 评论(0) 收藏 举报 分类: php学习感想(1) 版权声明:本文为 ... 
- [buaa-SE-2017]个人作业-week3
			个人作业-week3:案例分析 分析产品:Bing词典 Part1:调研&评测 1.软件评测和Bug汇报 这次我选择Bing词典的原因是在于,首先我使用过的词典软件较多,平台涵盖PC端.网站. ... 
- jsp九大内置对象之一request
			request对象,目的是用来获取客户端的请求. 主要方法有: request.getMethod(); // 获取提交请求的方式 request.getPr ... 
- Leetcode题库——12.整数转罗马数字
			@author: ZZQ @software: PyCharm @file: intToRoman.py @time: 2018/9/28 21:59 要求: 字符 数值 I 1 V 5 X 10 L ... 
- 关于Keil C51中“ERROR L107: ADDRESS SPACE OVERFLOW ”的总
			最近写一个关于单片机播放音乐的程序,出现如下错误: *** ERROR L107: ADDRESS SPACE OVERFLOW ... ... Program Size: data=167.6 xd ... 
