hdu4750Count The Pairs(最小生成树找瓶颈边)
/*
题意:就是给你一个图,图的每两个点都有多条路径,每一条路径中都有一条最大边,
所有最大边的最小边(也就是瓶颈边)就是这两点之间的val值!然后给你一个值f,
问有多少个顶点对的val>=f! (u,v) 和 (v, u)是不同的顶点对! 思路:最小生成树(kruskral)那么每两个节点(u,v)的瓶颈边就是这一棵树中u到v
的路径中的最大边值!
在利用并查集的过程中,A, B两个集合,如果有u属于A,v属于B,且u-v可以将
A-B集合连接起来,因为边值由小到大选取,那么以u-v边为瓶颈边的节点的个数
就是[A]*[B]*2; 注意:图不一定是连通的,开始的时候当成了一棵树,怎么改都不对!
*/
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#define N 10105
#define M 500105
using namespace std;
int f[N];
struct Edge{
int u, v, w;
Edge(){}
Edge(int u, int v, int w){
this->u=u;
this->v=v;
this->w=w;
}
}; Edge edge[M];
int dist[N];
int rank[N];
int cnt[N];
int edgeN;
int sumN[N];
int n, m; bool cmp(Edge a, Edge b){
return a.w < b.w;
} int getFather(int x){
return x==f[x] ? x : f[x]=getFather(f[x]);
} bool Union(int a, int b){
a=getFather(a);
b=getFather(b);
if(a!=b){
cnt[++edgeN]=sumN[a]*sumN[b]*;//记录以这一条边为瓶颈边的节点对的个数
if(rank[a]>rank[b]){
f[b]=a;
sumN[a]+=sumN[b];//将b集合放入到a集合中去
}
else{
f[a]=b;
sumN[b]+=sumN[a];//将a集合放入到b集合中去
++rank[b];
}
return true;
}
return false;
} void Kruskral(){
edgeN=;
sort(edge, edge+m, cmp);
for(int i=; i<=n; ++i)
f[i]=i, rank[i]=, sumN[i]=;
for(int i=; i<m; ++i)
if(Union(edge[i].u, edge[i].v))
dist[edgeN]=edge[i].w;//记录最小生成树中的边值
cnt[edgeN+]=;
for(int i=edgeN; i>=; --i)//统计大于等于第i条边为瓶颈边边值的所有节点对的对数
cnt[i]+=cnt[i+];
} int main(){
int p;
while(scanf("%d%d", &n, &m)!=EOF){
for(int i=; i<m; ++i){
int u, v, w;
scanf("%d%d%d", &u, &v, &w);
edge[i]=Edge(u+, v+, w);
}
Kruskral();
scanf("%d", &p);
while(p--){
int x;
scanf("%d", &x);
int index=lower_bound(dist+, dist+edgeN+, x)-dist;
if(index>edgeN) printf("0\n");
else printf("%d\n", cnt[index]);
}
}
return ;
}
//如果最后只有一棵树的话,这样做就可以了!没想到可能不是仅仅一棵树
1 #include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#define N 10105
#define M 500105
using namespace std;
int f[N];
struct Edge{
int u, v, w;
Edge(){}
Edge(int u, int v, int w){
this->u=u;
this->v=v;
this->w=w;
}
}; Edge edge[M];
int dist[N];
int rank[N];
int cnt[N];
int edgeN; int n, m; bool cmp(Edge a, Edge b){
return a.w < b.w;
} int getFather(int x){
return x==f[x] ? x : f[x]=getFather(f[x]);
} bool Union(int a, int b){
a=getFather(a);
b=getFather(b);
if(a!=b){
if(rank[a]>rank[b])
f[b]=a;
else{
f[a]=b;
++rank[b];
}
return true;
}
return false;
} void Kruskral(){
edgeN=;
sort(edge, edge+m, cmp);
for(int i=; i<=n; ++i)
f[i]=i, rank[i]=;
for(int i=; i<m; ++i)
if(Union(edge[i].u, edge[i].v))
dist[++edgeN]=edge[i].w;
cnt[edgeN+]=;
for(int i=edgeN; i>=; --i){
cnt[i]=i*;
cnt[i]+=cnt[i+];
}
} int main(){
int p;
while(scanf("%d%d", &n, &m)!=EOF){
for(int i=; i<m; ++i){
int u, v, w;
scanf("%d%d%d", &u, &v, &w);
edge[i]=Edge(u+, v+, w);
}
Kruskral();
scanf("%d", &p);
while(p--){
int x;
scanf("%d", &x);
int index=lower_bound(dist+, dist+edgeN+, x)-dist;
if(index>edgeN) printf("0\n");
else printf("%d\n", cnt[index]);
}
}
return ;
}
hdu4750Count The Pairs(最小生成树找瓶颈边)的更多相关文章
- HDU-4750 Count The Pairs 最小生成树,并查集
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4750 题意:Q个询问t,求在一个无向图上有多少对点(i,j)满足 i 到 j 的所有路径上的最长边的最 ...
- UVA - 11354 Bond(最小生成树+LCA+瓶颈路)
题意:N个点,M条路,每条路的危险度为路上各段中最大的危险度.多组询问,点s到点t的所有路径中最小的危险度. 分析: 1.首先建个最小生成树,则s到t的路径一定是危险度最小的. 原因:建最小生成树的最 ...
- Codeforces 632F - Magic Matrix(暴力 bitset or Prim 求最小生成树+最小瓶颈路)
题面传送门 开始挖老祖宗(ycx)留下来的东西.jpg 本来想水一道紫题作为 AC 的第 500 道紫题的,结果发现点开了道神题. 首先先讲一个我想出来的暴力做法.条件一和条件二直接扫一遍判断掉.先将 ...
- 并查集+二分-hdu-4750-Count The Pairs
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4750 题目大意: 给一无向图,n个点,m条边,每条边有个长度,且不一样.定义f(i,j)表示从节点i ...
- 图解最小生成树 - 克鲁斯卡尔(Kruskal)算法
我们在前面讲过的<克里姆算法>是以某个顶点为起点,逐步找各顶点上最小权值的边来构建最小生成树的.同样的思路,我们也可以直接就以边为目标去构建,因为权值为边上,直接找最小权值的边来构建生成树 ...
- HDU 4081 Qin Shi Huang's National Road System 最小生成树
点击打开链接题目链接 Qin Shi Huang's National Road System Time Limit: 2000/1000 MS (Java/Others) Memory Lim ...
- bzoj列表2
之前发过一次了,这里的题较水,没什么好讲的 bzoj1088 直接穷举前两位即可,话说程序员的扫雷是白玩的? bzoj1083 裸的最小生成树(最小生成树=最小瓶颈树),SCOI大丈夫(话说网上二分是 ...
- 正睿OI国庆DAY2:图论专题
正睿OI国庆DAY2:图论专题 dfs/例题 判断无向图之间是否存在至少三条点不相交的简单路径 一个想法是最大流(后来说可以做,但是是多项式时间做法 旁边GavinZheng神仙在谈最小生成树 陈主力 ...
- OI知识点/得分技巧的归纳总结
网络流 拆点/拆边技巧 题目来源 bzoj1070 题目描述 同一时刻有\(N\)位车主带着他们的爱车来到了汽车维修中心.维修中心共有\(M\)位技术人员,不同的技术人员对不同 的车进行维修所用的时间 ...
随机推荐
- SQL分页常用的两个存储过程
在做数据绑定时,我们常常会遇到分页事件,下面记录一下分页常用到SQL的两个存储过程 ①/****分页数据总数****//****** 对象: StoredProcedure [dbo].[GetRe ...
- 第51讲:Scala中链式调用风格的实现代码实战及其在Spark编程中的广泛运用
今天学习了下scala中的链式调用风格的实现,在spark编程中,我们经常会看到如下一段代码: sc.textFile("hdfs://......").flatMap(_.spl ...
- C2第十次解题报告
看过题解后如果觉得还算有用,请帮忙加点我所在团队博客访问量 http://www.cnblogs.com/newbe/ http://www.cnblogs.com/ne走迷宫wbe/p/406983 ...
- U盘的不识别问题
1.案例: 我重新装过电脑以后出现过一个问题是: 我的U盘只能在我电脑上用,在其他电脑上不能用 其他人的U盘不能在我的电脑上用. 2.根本问题: 是驱动问题.接口上没符合的驱动,未能指定路径.电脑上可 ...
- IIS部署ASP.NET常见错误
今天本地 IIS部署一个.NET Framework 3.5 项目,首先出现一个错误: 静态机制没有办法处理脚本 检查MIME没有问题,检查应用程序池版本,2.0, 果断改成 4.0. 运行之后新错误 ...
- 【leetcode】Pow(x,n)
马上各种校招要开始了,怎么也得准备一下,之前一直在看看机器学习,NLP方面的东西,收获很多.最近换换脑子,回过头来做做leetcode,感觉还是蛮有意思的.今天刷了个水题,AC不高,然而难度也不高.. ...
- java 动态代理示例,带主要注释
Java proxy是基于反射,仅仅支持基于接口的动态代理. java 动态代理是一切架构的基础,必须了解. 废话少说,先上代码获得感性认识. 示例代码有主要注释. 接口: public interf ...
- WebAPI的一种单元测试方案
大家是如何对webApi写测试的呢? 1.利用Fiddler直接做请求,观察response的内容. 2.利用Httpclient做请求,断言response的内容. 3.直接调用webApi的act ...
- Viewbox在UWP开发中的应用
Windows 8.1 与Windows Phone 8.1的UAP应用,终于在Windows 10上统一到了UWP之下.原来3个不同的project也变为一个.没有了2套xaml页面,我们需要用同一 ...
- Winform启动隐藏,WebBrowser交互JS
一.启动隐藏 Winform比较奇怪,Load的时候设置Visiable=false,无效.webBrowser_DocumentCompleted之后调用hide隐藏了窗体,但是在notifyIco ...