原文链接http://www.cnblogs.com/zhouzhendong/p/9010945.html

题目传送门 - Codechef STMINCUT

题意

  在一个有边权的无向图中,我们定义$S$和$T$的最小割为,要使得不存在$S$和$T$之间的路径需要删去的边的最小边权和。 给定$N×N$的二维数组$A$,你可以令数组的任意元素加上一个非负整数(每个元素加上的数可以不同)。加完后,数组$A$应当满足这一条件:存在$N$个节点的图$G$(节点编号为$1$∼$N$),使 得对于任意$i, j (1 ≤ i, j ≤ N)$,$i$和$j$在图$G$中的最小割恰好为$A_{i,j}$。我们定义上述操作的代价为加上的数字之和。请求出最小代价。

  多组数据。

  $T\leq 100,N\leq 1000,\sum N\leq 2000,A_{i,j}\leq 10^9$

题解

  先大力猜一个结论!!(后面填坑)

  最后得到的图是个森林。

  考虑到两点之间的最小割就是他们两个之间的树上路径的最小边权(如果不连通那么显然是$0$)。

  考虑到如果某一条边是某一个连通块中最小的边,那么这条边连通的两个连通块之间的点对之间的最小割显然是该边的权值。

  于是我们考虑从大到小加边。

  由于我们要最小化增量,所以我们取的边权就是输入的矩阵中的数字。

  显然可以$kruskal$来做。

  下面我们分情况讨论:

  如果当前要加入的边所对应的两个连通块

    $\rightarrow$ 不连通:那么,由于当前加入的边比之前加入的都要小,而当前还没有连通的所有点的最小割都不大于当前边权,所以用当前边连接对应的两个连通块中的任意两个点之后,不改变原来连通块内的最小割,并使得两个连通块之间的任意两点最小割大小提升到当前边权值。考虑到如果使该边的权值更大,显然会亏。

    $\rightarrow$ 连通:比如已经存在一条边沟通了两个连通块,并且修改了当前边所连接的两个节点的最小割值,所以当前边已经废了。不管他就可以了。

  然后我们只需要把任意两个节点之间的最小割总和算出来,减掉原来的矩阵数总和即可。

  然后我们考虑(yy)一下为什么森林是最优的(当然不是森林也可能是最优的)。

  开始口胡:

  考虑按照最小割需求从大到小做,在连接两个联通块的时候,如果选择连接的边不止一条边,那么每条边的权会比当前最小割需求平均一些。这样会导致一条路径的最小割不一定是新加入的边——由于之前可能已经加入较小的边了。所以我们需要在这个基础上继续添加边(显然已经亏了)。如果之前没有加入“较小的边”,那么新加入的边连接联通块之后,得到的效果和连一条树边效果相同。

  所以,最终结果为森林虽然不一定是唯一一个最优结果图,但是一定是最优的。

代码

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N=2005;
int T,n,a[N][N],fa[N],size[N];
LL ans,tot;
struct Point{
int x,y;
Point(){}
Point(int _x,int _y){
x=_x,y=_y;
}
}v[N*N];
int getf(int x){
return fa[x]==x?x:fa[x]=getf(fa[x]);
}
bool cmp(Point x,Point y){
return a[x.x][x.y]>a[y.x][y.y];
}
int main(){
scanf("%d",&T);
while (T--){
scanf("%d",&n);
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++){
scanf("%d",&a[i][j]);
v[(i-1)*n+j]=Point(i,j);
}
sort(v+1,v+n*n+1,cmp);
for (int i=1;i<=n;i++)
fa[i]=i,size[i]=1;
ans=tot=0;
for (int i=1;i<=n*n;i++){
int x=getf(v[i].x),y=getf(v[i].y);
if (x==y)
continue;
ans+=1LL*a[v[i].x][v[i].y]*size[x]*size[y];
size[x]+=size[y],fa[y]=x;
}
ans*=2;
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
ans-=a[i][j];
printf("%lld\n",ans);
}
return 0;
}

  

Codechef STMINCUT S-T Mincut (CodeChef May Challenge 2018) kruskal的更多相关文章

  1. Codechef October Challenge 2018 游记

    Codechef October Challenge 2018 游记 CHSERVE - Chef and Serves 题目大意: 乒乓球比赛中,双方每累计得两分就会交换一次发球权. 不过,大厨和小 ...

  2. Codechef September Challenge 2018 游记

    Codechef September Challenge 2018 游记 Magician versus Chef 题目大意: 有一排\(n(n\le10^5)\)个格子,一开始硬币在第\(x\)个格 ...

  3. Codeforces Avito Code Challenge 2018 D. Bookshelves

    Codeforces Avito Code Challenge 2018 D. Bookshelves 题目连接: http://codeforces.com/contest/981/problem/ ...

  4. Lyft Level 5 Challenge 2018 - Final Round (Open Div. 2) (前三题题解)

    这场比赛好毒瘤哇,看第四题好像是中国人出的,怕不是dllxl出的. 第四道什么鬼,互动题不说,花了四十五分钟看懂题目,都想砸电脑了.然后发现不会,互动题从来没做过. 不过这次新号上蓝名了(我才不告诉你 ...

  5. codechef February Challenge 2018 简要题解

    比赛链接:https://www.codechef.com/FEB18,题面和提交记录是公开的,这里就不再贴了 Chef And His Characters 模拟题 Chef And The Pat ...

  6. Codechef CHSIGN Change the Signs(May Challenge 2018) 动态规划

    原文链接http://www.cnblogs.com/zhouzhendong/p/9004583.html 题目传送门 - Codechef CHSIGN 题意 第一行,一个数$T$,表示数据组数. ...

  7. Codechef August Challenge 2018 : Chef at the River

    传送门 (要是没有tjm(Sakits)的帮忙,我还真不知道啥时候能做出来 结论是第一次带走尽可能少的动物,使未带走的动物不冲突,带走的这个数量就是最优解. 首先这个数量肯定是下界,更少的话连第一次都 ...

  8. Codechef August Challenge 2018 : Safe Partition

    传送门 (虽然是A了但是不知道复杂度是不是正确的 考虑以某个位置为结尾的合法划分 先考虑min,带来的影响是限制了最小长度,预处理出这个最小长度后,这可以在处理到这个数时,把不能算的部分去掉(不满足m ...

  9. Codechef August Challenge 2018 : Interactive Matrix

    传送门 首先整个矩阵可以被分为很多小矩阵,小矩阵内所有行的单调性是一样的,所有列的单调性是一样的. 考虑如何在这样一个小矩阵中找出答案.我的策略是每次取四个角中最大值和最小值的点,这样可以每次删掉一行 ...

随机推荐

  1. 本地项目提交到github和提交更新(转)

    一:首先当然是去github注册账号了. 二:注册完毕登录后,在自己的首页上面点击右上角“+”号,然后选择New repository,或者直接点击下面的绿色按钮,创建一个新仓库.如图: 然后填入仓库 ...

  2. Django 笔记(五)自定义标签 ~ 映射mysql

    创建简单标签: 1-3 或者 2-3 创建包含标签: 1-2或1-3或1-4(推荐) 包含标签使用: 2 和 4对应上面的使用方法 在虚拟环境中安装: pip install pymysql 在set ...

  3. Tornado学习笔记(一) helloword/多进程/启动参数

    前言 当你觉得你过得很舒服的时候,你肯定没有在进步.所以我想学习新的东西,然后选择了Tornado.因为我觉得Tornado更匹配目前的我的综合素质. Tornado学习笔记系列主要参考<int ...

  4. php学习随笔--定时触发

    PHP访问接口方法:

  5. Confluence 6 为空白空间重置原始默认内容

    希望重置为原始的默认内容: 在屏幕的右上角单击 控制台按钮 ,然后选择 General Configuration 链接. 在左侧的面板中选择 全局模板和蓝图(Global Templates and ...

  6. Guideline 5.2.1 - Legal - Intellectual Property 解决方案

    最近在上架公司公司项目的时候遇到这个问题什么5.2.1 然后去了解发现最近不少人都遇到了这个问题.先说一下 我上架的APP是一个医疗的APP然后说需要什么医疗资质,估计是账号的公司资质不够吧.后面和苹 ...

  7. 图书管理系统(无中间件,用装饰器的)-----未基于FORM组件

    目的:实现图书的增删改查 models.py from django.db import models # Create your models here. class Book(models.Mod ...

  8. servlet 乱码解决方法

    一. servlet 发送的html 页面中文乱码 解决方法, 1.加入如下代码 response.setCharacterEncoding("UTF-8"); 2.在html页面 ...

  9. git push -u 用法

    在我们第一次提交git的时候: 发现上面用了这个-u参数,也没作解释,特意搜索了下这个-u的用法,加了参数-u后,以后即可直接用git push 代替git push origin master gi ...

  10. Loadrunner常用目录、组成部分及负载测试流程

    常用目录 bin:存放一些可执行程序 classes:可能用到的jar包 My Template:存放一些自己创建的模板 include:头文件(可以编写自定义函数,保存成.h的头文件形式并放在这个目 ...