BZOJ3559 : [Ctsc2014]图的分割
考试的时候看少了一行,导致暴力都写错额…
贾教说他出的这题水,但是我觉得并不水,那个结论还是很神的。
首先M(i)就是i的最小生成树的最大边,
设f[i]表示i属于哪个集合
我们把边按权值从小到大排序,对于一条边(u,v),权值为w,
如果w<=min(M(f[u])+Z[C[f[u]]],M(f[v])+Z[C[f[v]]]),
那么u,v就不能分开,否则不满足“半完美”这个条件,那就把它们放入一个集合。
搞完之后扫一遍输出每个集合即可。
至于怎么证明正确性,我也不知道。
- #include<cstdio>
- #include<algorithm>
- #define N 100010
- using namespace std;
- inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}
- struct pp{int u,v,w;}a[500010];
- inline bool cmp(pp a,pp b){return a.w<b.w;}
- int n,m,i,j,z[N],M[N],c[N],f[N],ed,g[N],nxt[N<<1],v[N<<1],k,cnt[N];
- inline void add(int x,int y){v[++ed]=y;nxt[ed]=g[x];g[x]=ed;}
- void go(int x,int pre,int y){
- f[x]=y;
- for(int i=g[x];i;i=nxt[i])if(v[i]!=pre)go(v[i],x,y);
- }
- inline void link(int x,int y,int z){
- if(f[x]==f[y])return;
- if(c[f[x]]>c[f[y]])swap(x,y);
- c[f[y]]+=c[f[x]];M[f[y]]=z;
- go(x,0,f[y]);
- add(x,y);add(y,x);
- }
- int main(){
- read(n);read(m);
- for(i=1;i<=n;i++)read(z[i]);
- for(i=1;i<=m;i++)read(a[i].u),read(a[i].v),read(a[i].w);
- sort(a+1,a+m+1,cmp);
- for(i=1;i<=n;i++)f[i]=i,c[i]=1;
- for(i=1;i<=m;i++)if(a[i].w<=min(M[f[a[i].u]]+z[c[f[a[i].u]]],M[f[a[i].v]]+z[c[f[a[i].v]]]))link(a[i].u,a[i].v,a[i].w);
- for(i=1;i<=n;i++)g[i]=0;
- ed=0;
- for(i=1;i<=n;i++){
- if(!cnt[f[i]])k++;
- cnt[f[i]]++;
- add(f[i],i);
- }
- for(printf("%d\n",k),i=1;i<=n;i++)if(cnt[i]){
- for(printf("%d",cnt[i]),j=g[i];j;j=nxt[j])printf(" %d",v[j]);
- puts("");
- }
- return 0;
- }
BZOJ3559 : [Ctsc2014]图的分割的更多相关文章
- [Ctsc2014]图的分割
[Ctsc2014]图的分割 阅读理解好题 翻译一下: M(C)就是C这个诱导子图最小生成树最大边权 结论: 按照w进行sort,如果满足w<=Ci,Cj表示u,v的连通块的诱导子图 并且Ci! ...
- bzoj 3559: [Ctsc2014]图的分割【最小生成树+并查集】
读题两小时系列-- 在读懂题意之后,发现M(c)就是c这块最大权割边也就是的最小生成树的最大权边的权值,所以整个问题都可以在MST的过程中解决(M和c都是跟着并查集变的) 不过不是真的最小生成树,是合 ...
- hdu 3435 图回路分割
将一个无向图分成许多回路,回路点交集为空,点幷集为V.幷最小化回路边权和. #include <cstdio> #include <cstring> #include < ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- 基于谱聚类的三维网格分割算法(Spectral Clustering)
谱聚类(Spectral Clustering)是一种广泛使用的数据聚类算法,[Liu et al. 2004]基于谱聚类算法首次提出了一种三维网格分割方法.该方法首先构建一个相似矩阵用于记录网格上相 ...
- I-图的分割(二分+并查集)
图的分割 题目大意: 给你n个点,m条边的图,没有重环和自环,所有的点都联通 可以通过删除几条边使得整个图变成两个联通子图 求删除的边中最大边权的最小值 解题思路: 看到"最大边权的最小值& ...
- 【CSS进阶】试试酷炫的 3D 视角
写这篇文章的缘由是因为看到了这个页面: 戳我看看(移动端页面,使用模拟器观看) 运用 CSS3 完成的 3D 视角,虽然有一些晕3D,但是使人置身于其中的交互体验感觉非常棒,运用在移动端制作一些 H5 ...
- CSS3与页面布局学习总结(六)——CSS3新特性(阴影、动画、渐变、变形、伪元素等)
CSS3在CSS2.1的基础上新增加了许多属性,这里选择了较常用的一些功能与大家分享,帮助文档中有很详细的描述,可以在本文的示例中获得帮助文档. 一.阴影 1.1.文字阴影 text-shadow&l ...
- iOS10 推送必看(基础篇)
虽然这篇文章比较长,也不好理解,但是还是建议大家收藏,以后用到的时候,可以看看,有耐心的还是读一读. 这篇文章开始,我会跟大家好好讲讲,苹果新发布的iOS10的所有通知类. 一.创建本地通知事例详解: ...
随机推荐
- 使用Gson送解析Json格式
Java bean: package com.jingle.a; public class Person { public String name; public int age; public Pe ...
- http://poj.org/problem?id=3278(bfs)
Catch That Cow Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 76935 Accepted: 24323 ...
- Cannot return from outside a function or method
最近发现myeclipse10中有几处bug 比如: Cannot return from outside a function or method onClick="return chec ...
- 随机数组&大数相加
随机生成10个数,填充一个数组,然后用消息框显示数组内容,接着计算数组元素的和,将结果也显示在消息框中 一, 设计思路: 先生成随机数数组,再将数组保存在一个字符串中,然后将数组各数字加和, ...
- php文件上传进度条例子
<?php session_start(); ?> <!DOCTYPE html> <html lang="zh-CN"> <head&g ...
- Spring+Maven+Dubbo+MyBatis+Linner+Handlebars—Web开发环境搭建
本文主要分三部分,分别是:后台核心业务逻辑.桥梁辅助控制和前台显示页面. 本Web开发环境综合了多种工具,包括Maven包管理与编译工具.Dubbo分布式服务框架.MyBatis数据持久化工具.Lin ...
- Delphi开发中各种文件扩展名代表什么文件
暂时就遇到了以下这几种,以后遇到再进行补充 .DPR Delphi Project文件,打开这个文件,就会打开所有的编程的代码文件.包含了Pascal代码 .PAS Pascal文件,Pascal单元 ...
- VC++6.0使用OpenGL前的配置(必看)
要在VC++6.0中使用opengl,需要配置一下环境设置. 具体需要两步: 1.加入一个头文件,两个lib文件,两个dll文件,放在合适位置. 2.配置一下vc++6.0的Project Setti ...
- 老生常谈,正确使用memset
转自:http://blog.csdn.net/my_business/article/details/40537653 前段项目中发现一个问题,程序总是在某个dynamic_cast进行动态转换时出 ...
- Sql Server 基础知识
Sql Server 基础知识: http://blog.csdn.net/t6786780/article/details/4525652 Sql Server 语句大全: http://www.c ...