Problem Description

在图论中,树:随意两个顶点间有且仅仅有一条路径的图。

生成树:包括了图中全部顶点的一种树。

最小生成树:对于连通的带权图(连通网)G,其生成树也是带权的。

生成树T各边的权值总和称为该树的权,权最小的生成树称为G的最小生成树(Minimum Spanning Tree)。最小生成树可简记为MST。

可是,对于一个图而言。最小生成树并非唯一的。

如今,给你一个连通的有权无向图,图中不包括有自环和重边。你的任务就是寻找出有多少条边,它至少在一个最小生成树里。图保证连通。

 Input

输入数据第一行包括一个整数T,表示測试数据的组数。对于每组測试数据:

第一行包括两个整数n,m(1<n<100000,n-1<m<100000)。接下来m行,每行三个整数a,b,v(1<=a,b<=n,1<v<500),表示第i条路线连接景点A和景点B,距离是V。两个数字之间用空格隔开。

 Output

对于每组測试数据,输出一行,包括一个整数,表示满足条件的边的个数。

 Sample Input

14 51 2 1011 3 1002 3 22 4 23 4 1

 Sample Output

4

 Source

福州大学第九届程序设计竞赛

解题思路:

一棵树能够有多个最小生成树,可是他们的权值一定是相等的。

按权值从小到大对边排序,然后把权值同样的边归为一组,推断时候,仅仅要一个边的两个端点不在同一个集合,那么该边就能够增加到最小生成树里面。

代码:

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
const int maxn=100005;
const int maxm=100005;
int n,m;
int parent[maxn]; struct Node
{
int from,to,w;
}node[maxm]; void init(int n)
{
for(int i=1;i<=n;i++)
parent[i]=i;
} int find(int x)
{
if(parent[x]==x)
return x;
else
return parent[x]=find(parent[x]);
} bool same(int x,int y)
{
return find(x)==find(y);
}
void unite(int x,int y)
{
parent[find(x)]=find(y);
} bool cmp(Node a,Node b)
{
return a.w<b.w;
} void solve()
{
int cnt=0;
int i,j;
for(i=1;i<=m;i=j)
{
for(j=i;node[j].w==node[i].w;j++)//仅仅要同样权值的边两个端点不在同一个集合。该边就一定存在一个最小生成树里面
{
if(!same(node[j].from,node[j].to))
cnt++;
}
for(j=i;node[j].w==node[i].w;j++)//有回路的边加上不影响后面的加边
unite(node[j].from,node[j].to);
}
printf("%d\n",cnt);
} int main()
{
int t;scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
init(n);
for(int i=1;i<=m;i++)
scanf("%d%d%d",&node[i].from,&node[i].to,&node[i].w);
sort(node+1,node+1+m,cmp);
solve();
}
return 0;
}

[ACM] FZU 2087 统计数边 (有多少边至少存在一个最小生成树里面)的更多相关文章

  1. FZU 2087 统计树边【MST相关】

     Problem 2087 统计树边 Accept: 212    Submit: 651 Time Limit: 1000 mSec    Memory Limit : 32768 KB  Prob ...

  2. FZU 2087 统计树边

    这题第一直觉就是和CF第三次教育场的E题是一样的, http://codeforces.com/contest/609/problem/E 然后直接拉过来代码改了改,提交返回MLE.FZU内存开的小, ...

  3. COJ 0036 数数happy有多少个?

    数数happy有多少个? 难度级别:B: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 图图是个爱动脑子.观察能力很强的好学生.近期他正学英语 ...

  4. [ACM] hdu 1251 统计难题 (字典树)

    统计难题 Problem Description Ignatius近期遇到一个难题,老师交给他非常多单词(仅仅有小写字母组成,不会有反复的单词出现),如今老师要他统计出以某个字符串为前缀的单词数量(单 ...

  5. 数集合有多少个TOJ(2469)

    题目链接:http://acm.tju.edu.cn/toj/showp2469.html 感觉这个题目有点问题,算了不管他了,反正A了. 这里要注意的是求这个集合有多少种,那么就是要剔除重复数后,再 ...

  6. 一张表有三个字段:id(城市id) Cityname(城市名) Privence(所属省份)如果要统计每个省份有多少城市请用SQL实现。

    一张表有三个字段:id(城市id) Cityname(城市名) Privence(所属省份)如果要统计每个省份有多少城市请用SQL实现.

  7. FZU 2231 平行四边形数

    FZU - 2231  平行四边形数 题目大意:给你n个点,求能够组成多少个平行四边形? 首先想到的是判断两对边平行且相等,但这样的话得枚举四个顶点,或者把点转换成边然后再枚举所有边相等的麻烦,还不好 ...

  8. C语言100题集合005-删除一维数组中所有相同的数,使之只剩一个

    系列文章<C语言经典100例>持续创作中,欢迎大家的关注和支持. 喜欢的同学记得点赞.转发.收藏哦- 后续C语言经典100例将会以pdf和代码的形式发放到公众号 欢迎关注:计算广告生态 即 ...

  9. ACM: FZU 2105 Digits Count - 位运算的线段树【黑科技福利】

     FZU 2105  Digits Count Time Limit:10000MS     Memory Limit:262144KB     64bit IO Format:%I64d & ...

随机推荐

  1. Shell 进度条效果的一个实现

    #!/bin/bash processBar() { now=$ all=$ percent=`awk BEGIN'{printf "%f", ('$now'/'$all')}'` ...

  2. POJ 2029 Get Many Persimmon Trees (二维树状数组)

    Get Many Persimmon Trees Time Limit:1000MS    Memory Limit:30000KB    64bit IO Format:%I64d & %I ...

  3. Unix环境部署

    http://www.cnblogs.com/chuyuhuashi/p/4423699.html 分布式javahttp://www.cnblogs.com/tangyanbo/p/4499485. ...

  4. 编辑器未包含main类型

    明明写了main函数,在运行的时候,却得到这样的结果. 解决方案: 重新建立一个项目,建立项目的过程中

  5. java精确除法计算,四舍五入 Java问题通用解决代码

    主要用java.math.BigDecimal工具类实现,想要了解BigDecimal类可以看java api   正式版:        public static Double divide() ...

  6. UITextView被键盘遮挡的处理

    这个应该是一个通用的任务了吧,键盘弹出来的时候,UITextView(或者UITextField)会被遮挡. 解决的办法就不是很能通用了. 1. 如果有UIScrollView做父view的话只需要滚 ...

  7. mysql中去重复记录

    Distinct 这个只能放在查询语句的最前面 参考 : https://www.cnblogs.com/lushilin/p/6187743.html

  8. 【POJ 2400】 Supervisor, Supervisee(KM求最小权匹配)

    [POJ 2400] Supervisor, Supervisee(KM求最小权匹配) Supervisor, Supervisee Time Limit: 1000MS   Memory Limit ...

  9. CentOS yum 命令出现 [Errno 14] curl#6 - &quot;Couldn&#39;t resolve host ...&quot; 的解决方法

    安装svn的时候,发现报错说一个地址无法訪问. # yum list | grep subversion http://opensource.wandisco.com/centos/7/svn-1.8 ...

  10. poj 2367

    Genealogical tree Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3658   Accepted: 2433 ...