There is No Alternative

题目连接:

http://codeforces.com/gym/100803/attachments

Description

ICPC (Isles of Coral Park City) consist of several beautiful islands.

The citizens requested construction of bridges between islands to resolve inconveniences of using

boats between islands, and they demand that all the islands should be reachable from any other

islands via one or more bridges.

The city mayor selected a number of pairs of islands, and ordered a building company to estimate

the costs to build bridges between the pairs. With this estimate, the mayor has to decide the

set of bridges to build, minimizing the total construction cost.

However, it is difficult for him to select the most cost-efficient set of bridges among those

connecting all the islands. For example, three sets of bridges connect all the islands for the

Sample Input 1. The bridges in each set are expressed by bold edges in Figure F.1.

Figure F.1. Three sets of bridges connecting all the islands for Sample Input 1

As the first step, he decided to build only those bridges which are contained in all the sets

of bridges to connect all the islands and minimize the cost. We refer to such bridges as no

alternative bridges. In Figure F.2, no alternative bridges are drawn as thick edges for the

Sample Input 1, 2 and 3.

Write a program that advises the mayor which bridges are no alternative bridges for the given

input.

Input

The first line contains two positive integers N and M. N represents the number of islands and

each island is identified by an integer 1 through N. M represents the number of the pairs of

islands between which a bridge may be built.

Each line of the next M lines contains three integers Si

, Di and Ci (1 ≤ i ≤ M) which represent

that it will cost Ci to build the bridge between islands Si and Di

. You may assume 3 ≤ N ≤ 500,

N − 1 ≤ M ≤ min(50000, N(N − 1)/2), 1 ≤ Si < Di ≤ N, and 1 ≤ Ci ≤ 10000. No two bridges

connect the same pair of two islands, that is, if i 6= j and Si = Sj , then Di 6= Dj . If all the

candidate bridges are built, all the islands are reachable from any other islands via one or more

bridges.

Output

Output two integers, which mean the number of no alternative bridges and the sum of their

construction cost, separated by a space.

Sample Input

4 4

1 2 3

1 3 3

2 3 3

2 4 3

Sample Output

1 3

Hint

题意

给你一个图,然后问你有哪些边一定在所有的最小生成树上面

题解:

点只有500,所以我们直接O(nm)暴力就好了

我们只用ban掉一开始在最小生成树上的边,然后判断就好了

代码

#include<bits/stdc++.h>
using namespace std; const int maxn = 100050; int u[maxn],v[maxn],w[maxn],r[maxn];
int pa[maxn],n,m;
int vis[maxn];
int ans1=0,ans2=0;
bool cmp(int i,int j)
{
return w[i]<w[j];
}
int fi(int x)
{
return pa[x]==x?x:pa[x]=fi(pa[x]);
}
int kruskal(int c)
{
int ans=0;
int num=0;
for(int i=0;i<=n;i++)
pa[i]=i;
for(int i=0;i<m;i++)
{
if(i==c)continue;
int e=r[i];
int x=fi(u[e]);
int y=fi(v[e]);
if(x!=y)
{
num++;
vis[i]=1;
ans+=w[e],pa[x]=y;
}
if(num==n-1)break;
}
if(num!=n-1)return -1;
return ans;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=0;i<m;i++)
{
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
u[i]=x,v[i]=y,w[i]=z;
}
for(int i=0;i<m;i++)
r[i]=i;
sort(r,r+m,cmp);
int temp = kruskal(m);
for(int i=0;i<m;i++)
{
if(!vis[i])continue;
if(temp!=kruskal(i))
{
ans1++;
ans2+=w[r[i]];
}
}
cout<<ans1<<" "<<ans2<<endl;
}

Codeforces Gym 100803F There is No Alternative 暴力Kruskal的更多相关文章

  1. Codeforces Gym 100286J Javanese Cryptoanalysis 傻逼暴力

    原题地址:http://codeforces.com/gym/100286/attachments/download/2013/20082009-acmicpc-northeastern-europe ...

  2. Codeforces Gym 100342C Problem C. Painting Cottages 暴力

    Problem C. Painting CottagesTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/1 ...

  3. Codeforces Gym 100513I I. Sale in GameStore 暴力

    I. Sale in GameStore Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100513/p ...

  4. Codeforces Gym 100203G G - Good elements 标记暴力

    G - Good elementsTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/ ...

  5. Codeforces Gym 100650D Queens, Knights and Pawns 暴力

    Problem D: Queens, Knights and PawnsTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu ...

  6. Codeforces Gym 101190M Mole Tunnels - 费用流

    题目传送门 传送门 题目大意 $m$只鼹鼠有$n$个巢穴,$n - 1$条长度为$1$的通道将它们连通且第$i(i > 1)$个巢穴与第$\left\lfloor \frac{i}{2}\rig ...

  7. Codeforces Gym 101252D&&floyd判圈算法学习笔记

    一句话题意:x0=1,xi+1=(Axi+xi%B)%C,如果x序列中存在最早的两个相同的元素,输出第二次出现的位置,若在2e7内无解则输出-1. 题解:都不到100天就AFO了才来学这floyd判圈 ...

  8. Codeforces Gym 101623A - 动态规划

    题目传送门 传送门 题目大意 给定一个长度为$n$的序列,要求划分成最少的段数,然后将这些段排序使得新序列单调不减. 考虑将相邻的相等的数缩成一个数. 假设没有分成了$n$段,考虑最少能够减少多少划分 ...

  9. 【Codeforces Gym 100725K】Key Insertion

    Codeforces Gym 100725K 题意:给定一个初始全0的序列,然后给\(n\)个查询,每一次调用\(Insert(L_i,i)\),其中\(Insert(L,K)\)表示在第L位插入K, ...

随机推荐

  1. IntelliJ IDEA svn 提交错误

    环境说明: 系统:Mac OS X 10.9 以及 10.10 系统设置:LANG=zh_CN.UTF-8 svn 客户端:1.8.10 IntelliJ IDEA 13 毫无疑问,IntelliJ ...

  2. jquery元素定位方法

    用chrome浏览器打开页面,按f12调出开发者调试模式,查看elements,部分代码如下图所示,注意红框部分 假设我们要查找某些元素的位置,用鼠标移到那部分元素,调试器会自动用蓝颜色标示选中部分的 ...

  3. SQL 教程学习进度备忘

    书签:跳过:另外跳过的内容有待跟进 __________________ 学习资源:W3School. _________________ 跳过的内容: 1.  “SQL select”底部的“ AD ...

  4. BPDU与PortFast

    启用了BPDU Guard特性的端口在收到BPDU的时候会使端口进入err-disable状态,从而避免桥接环路.一般BPDU Guard是和PortFast结合使用,在端口上启用了PortFast之 ...

  5. Ruiy自我识人做事领悟录ing

    是坑总需要人去踩,谁踩谁收获! 做人做事分层分次,后方能至始及终不乱; 做人做事切记诚记信,宁他人负我,我定不负他人! 做人做事做力求清心寡欲; 安静做工,沉静学道;

  6. Hadoop概念学习系列之hadoop生态系统闲谈(二十五)

    分层次讲解 最底层平台 ------->hdfs  yarn  mapreduce spark 应用层-------->hbase  hive   pig   sparkSQL    nu ...

  7. 【转】log4j详解及简易搭建

    原文链接:http://www.cnblogs.com/mailingfeng/archive/2011/07/28/2119937.html log4j是一个非常强大的log记录软件. 首先当然是得 ...

  8. #用Python直接写UTF-8文本文件

    当我们这样建立文件时 f = file('x1.txt', 'w') f.write(u'中文') f.colse() 直接结果应该是类似 f.write(u'中文') UnicodeEncodeEr ...

  9. poj 3264 Balanced Lineup(RMQ裸题)

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 43168   Accepted: 20276 ...

  10. Window服务初级教程以及log4net配置文件初始化

    Window服务初级教程:http://www.jb51.net/article/48987.htm 另外,配置log4net这个日志功能的时候需要初始化,不然会报没有初始化的错误,而且初始化的节点应 ...