博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Codeforces D - The Child and Zoo
阅读量:6113 次
发布时间:2019-06-21

本文共 976 字,大约阅读时间需要 3 分钟。

思路:

并查集+贪心

每条边的权值可以用min(a[u],a[v])来表示,然后按边的权值从大到小排序

然后用并查集从大的边开始合并,因为你要合并的这两个联通块之间的点肯定要经过这条边,而这条要合并的边是所有已经合并中的最小的,所以两个联通块之间的所有点之间的f就是这条边(而且是所有情况最大的,因为是从最大的边开始贪心的)。

代码:

#include
using namespace std;#define ll long long#define pb push_back#define mem(a,b) memset(a,b,sizeof(a))const int N=1e5+5;struct edge{ int u,v,w; bool operator < (edge t){ return w>t.w; }}edge[N];int cnt[N];int rnk[N];int par[N];int a[N];void init(int n){ for(int i=0;i<=n;i++)par[i]=i,cnt[i]=1;}int find(int x){ if(x==par[x])return x; else return par[x]=find(par[x]);}void unite(int x,int y){ int px=find(x); int py=find(y); if(px!=py){ if(rnk[px]
>n>>m; for(int i=1;i<=n;i++)cin>>a[i]; int c=0; while(m--){ cin>>u>>v; edge[c].u=u; edge[c].v=v; edge[c++].w=min(a[u],a[v]); } sort(edge,edge+c); init(n); ll ans=0; for(int i=0;i

 

转载于:https://www.cnblogs.com/widsom/p/8366282.html

你可能感兴趣的文章
并行程序设计学习心得1——并行计算机存储
查看>>
JAVA入门到精通-第86讲-半双工/全双工
查看>>
bulk
查看>>
js document.activeElement 获得焦点的元素
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
day6-if,while,for的快速掌握
查看>>
JavaWeb学习笔记(十四)--JSP语法
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>
angularjs表达式中的HTML内容,如何不转义,直接表现为html元素
查看>>
css技巧
查看>>
Tyvj 1728 普通平衡树
查看>>
[Usaco2015 dec]Max Flow
查看>>
javascript性能优化
查看>>
多路归并排序之败者树
查看>>
java连接MySql数据库
查看>>
转:Vue keep-alive实践总结
查看>>