离线+生成树+并查集——cf1213G
#include<bits/stdc++.h>
using namespace std;
#define N 200005
#define ll long long
struct Edge{int u,v,w;}e[N];
struct Query{int id,qq;}qq[N];
int n,q;
ll ans[N],sum;
bool operator<(Edge a,Edge b){return a.w<b.w;}
bool operator<(Query a,Query b){return a.qq<b.qq;} int F[N],size[N];
int find(int x){
if(F[x]==x)return x;
int f=find(F[x]);
return F[x]=f;
}
void bing(int u,int v){
int f1=find(u),f2=find(v);
if(f1==f2)return;
sum-=(ll)size[f1]*(size[f1]-)/;
sum-=(ll)size[f2]*(size[f2]-)/;
size[f1]+=size[f2];
sum+=(ll)size[f1]*(size[f1]-)/;
F[f2]=f1;
} int main(){
cin>>n>>q;
for(int i=;i<n;i++)
scanf("%d%d%lld",&e[i].u,&e[i].v,&e[i].w);
for(int i=;i<=q;i++)
scanf("%d",&qq[i].qq),qq[i].id=i;
sort(e+,e+n);
sort(qq+,qq++q); for(int i=;i<=n;i++)F[i]=i,size[i]=; int p=;
for(int i=;i<=q;i++){
while(qq[i].qq>=e[p].w && p<=n-){
int u=e[p].u,v=e[p].v;
bing(u,v);
p++;
}
ans[qq[i].id]=sum;
}
for(int i=;i<=q;i++)
cout<<ans[i]<<" ";
}
离线+生成树+并查集——cf1213G的更多相关文章
- 【bzoj5183】[Baltic2016]Park  离线+对偶图+并查集
		
题目描述 在Byteland的首都,有一个矩形围栏围起来的公园.在这个公园里树和访客都以一个圆形表示.公园有四个出入口,每个角落一个(1=左下角,2=右下角,3=右上角,4=左上角).访客能通过这些出 ...
 - HDU 5441 离线处理 + 并查集
		
题意:给n个节点m条带权值边的无向图.然后q个问题,每次询问点对的数目,点对需要满足的条件是:1)连通:2)其路径的最大权值不能超过询问值. 分析:如果没次询问一次,dfs一次,很可能超时,因此可以用 ...
 - HDU 4786 生成树 并查集+极大极小值 黑白边 确定选择白边的数量
		
题意: 给定一个无向图 n 个点 m条无向边 u v val val == 1 表示边(u, v) 为白边 问能否找到n个点的生成树, 使得白边数为斐波那契数 思路: 并查集求图是否连通( 是否存在生 ...
 - hdu Portal(离线,并查集)
		
题意:在一张无向图上,已知边权,做q组询问,问小于L的点对共有几组.点对间的距离取=min(两点之间每一条通路上的最大值). 分析:这里取最大值的最小值,常用到二分.而这里利用离线算法,先对边从小到大 ...
 - 【离线 撤销并查集 线段树分治】bzoj1018: [SHOI2008]堵塞的交通traffic
		
本题可化成更一般的问题:离线动态图询问连通性 当然可以利用它的特殊性质,采用在线线段树维护一些标记的方法 Description 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常 ...
 - hdu3938 Portal  离线的并查集
		
离线算法是将全部输入都读入,计算出所有的答案以后再输出的方法.主要是为避免重复计算.类似于计算斐波那契数列的时候用打表的方法. 题目:给一个无向图,求有多少个点对,使得两点间的路径上的花费小于L,这里 ...
 - 【XSY3345】生成树 并查集
		
题目大意 有一个两部各有 \(n\) 个节点的二分图 \(G\),定义 \(G^m\) 为一个 \(m+1\) 层的图,每层有 \(n\) 个节点,相邻两层的诱导子图都和 \(G\) 相同. 给你 \ ...
 - [hdu4585]离线,并查集
		
题意:把一些数加到集合里面,每个数有两个属性,分别是编号和值,加进去之前询问集合里面距离自己“最近”的数的编号.最近的意思是值的差的绝对值最小,如果有相等的,则取值小的.并且已知所有数的id和valu ...
 - [HDOJ2586]How far away?(最近公共祖先, 离线tarjan, 并查集)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 这题以前做过…现在用tarjan搞一发…竟然比以前暴力过的慢………… 由于是离线算法,需要Que ...
 
随机推荐
- 【网络】Vmware虚拟机下三种网络模式配置
			
VMware虚拟机有三种网络模式,分别是Bridged(桥接模式).NAT(网络地址转换模式).Host-only(主机模式). VMware workstation安装好之后会多出两个网络连接,分别 ...
 - PHP filter_id() 函数
			
定义和用法 filter_id() 函数返回指定过滤器的 ID 号. 如果成功则返回过滤器的 ID 号,如果过滤器不存在则返回 NULL. 语法 filter_id(filter_name) 参数 描 ...
 - 查看电脑是否安装jdk以及安装了的路径
			
1.输入cmd进入dos界面2.输入java -version,回车 C:\Users\Lenovo>java -versionjava version "1.7.0_71" ...
 - vue+express+mysql +node项目搭建
			
项目搭建前需要先安装node环境及mysql数据库. 1.利用vue-cli脚手架创建一个vue项目 a.全局安装 npm install -g vue-cli b.初始化项目 vue init we ...
 - log4j日志格式化
			
Apache log4j 提供了各种布局对象,每一个对象都可以根据各种布局格式记录数据.另外,也可以创建一个布局对象格式化测井数据中的特定应用的方法. 所有的布局对象 - Appender对象收到 L ...
 - 火狐foxyproxy + burp
			
下载 火狐foxyproxy 和 burp 两个代理ip端口填写一致 如果对于公司有正向代理服务器,则需要配置burp的上游代理 对于IE浏览器的代理是windows操作系统的全局代理,在ie配置代理 ...
 - editplus 正则表达式  分组替换
			
editplus :zz正则表达式替换 /开头的api+换行符 替换为 /开头的api+空格 \1后有空格 editplus :zz正则表达式替换 行首两个数字+换行符 替换为 行首两个数字+空 ...
 - DB2连接
			
ibm_db.connect 创建非持久连接. ibm_db.pconnect 创建持久连接. 在最初的Python脚本请求之后,持久的连接保持打开状态,这允许后续的Python请求重新使用连接. 后 ...
 - [轉]User namespaces – available to play!
			
User namespaces – available to play! Posted on May 10, 2012by s3hh Over the past few months, Eric Bi ...
 - Rabbitmq的延时队列的使用
			
配置: spring: rabbitmq: addresses: connection-timeout: username: guest password: guest publisher-confi ...