[codevs 1069 关押罪犯] [NOIP2010提高T3]
来源:互联网 发布:简单json格式 编辑:程序博客网 时间:2024/06/10 23:25
传送门http://codevs.cn/problem/1069/
将边从大到小排序,用并查集维护,第一条无法满足的边就是答案。重点在于如何记录哪些点不在同一个集合。我们给每一个实点A对应一个虚点A’。若要记录A、B两点不在同一集合即给A、B’以及B、A’之间连边。接下来,若要记录B、C两点不在同一集合,连边之后A、C就在同一集合了。
就不要吐槽我的图片丑了。。好不容易才画起来的呢。。
贴代码
/*作者:ymzQwQ题目:p1069 关押罪犯*/#include<iostream>#include<cstdio>#include<algorithm>using namespace std;const int N=20000,M=100000;int n,m,f[2*N+10],ans;struct data{ int x,y,z;}a[M+10];int gf(int x){ return f[x]==x?x:f[x]=gf(f[x]); }int cmp(const data q,const data w){ return q.z>w.z; }int main(){ scanf("%d%d",&n,&m); for(int i=1;i<=n*2;i++) f[i]=i; for(int i=1;i<=m;i++) scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].z); sort(a+1,a+1+m,cmp); for(int i=1;i<=m;i++){ int fx=gf(a[i].x),fy=gf(a[i].y); if (fx==fy){ ans=a[i].z;break; } else f[fx]=gf(a[i].y+n),f[fy]=gf(a[i].x+n); } printf("%d",ans); return 0;}
阅读全文
1 0
- [codevs 1069 关押罪犯] [NOIP2010提高T3]
- Codevs 1069关押罪犯[Noip2010]
- [NOIP2010 T3]关押罪犯
- TYVJ1403(NOIP2010提高组T3)关押罪犯
- NOIP2010提高组 关押罪犯
- NOIP2010提高组 关押罪犯
- NOIP2010提高组 关押罪犯
- 【NOIP2010提高组】关押罪犯
- 【NOIP2010提高组】关押罪犯
- 【NOIP2010提高组】关押罪犯
- 洛谷 P1525 [NOIP2010 T3] 关押罪犯
- codevs 1069 [NOIP2010] 关押罪犯 二分+二分图染色
- CODEVS 1069 关押罪犯
- Codevs-1069 关押罪犯
- 【codevs】1069 关押罪犯
- 【codevs 1069】关押罪犯
- CODEVS 1069关押罪犯
- codevs 1069 关押罪犯
- 2017北京网络赛
- POJ4084拓扑排序--DFS的应用
- 算法导论第二章《插入排序》
- ORA-27102: out of memory 解决实例
- iOS百度地图集成时反geo 检索发送失败和geo 检索发送失败
- [codevs 1069 关押罪犯] [NOIP2010提高T3]
- 汇编语言的学习
- 06:图像相似度
- python对象编程总结(一)
- Leetcode 9刷题 翻转监测回文(不用额外空间)
- Nginx 架构初探
- Integral Types and Values
- Android6.0权限(短信)—问题记录
- ValueAnimator插值器(Interpolors)和计值器(Evaluator)详解