一个无向连通网络,去掉一个边集可以使其变成两个连通分量则这个边集就是割集;最小割集当然就权和最小的割集。

可以用最小切割最大流定理:

1.min=MAXINT,确定一个源点

2.枚举汇点

3.计算最大流,并确定当前源汇的最小割集,若比min小更新min

4.转到2直到枚举完毕

5.min即为所求输出min

不难看出复杂度很高:枚举汇点要O(n),最短增广路最大流算法求最大流是O((n^2)m)复杂度,在复杂网络中O(m)=O(n^2),算法总复杂度 就是O(n^5);哪怕采用最高标号预进流算法求最大流O((n^2)(m^0.5)),算法总复杂度也要O(n^4)

所以用网络流算法求解最小割集复杂度不会低于O(n^4)。

---------

prim算法不仅仅可以求最小生成树,也可以求“最大生成树”。最小割集Stoer-Wagner算法就是典型的应用实例。

求解最小割集普遍采用Stoer-Wagner算法,不提供此算法证明和代码,只提供算法思路:

1.min=MAXINT,固定一个顶点P

2.从点P用“类似”prim的s算法扩展出“最大生成树”,记录最后扩展的顶点和最后扩展的边

3.计算最后扩展到的顶点的切割值(即与此顶点相连的所有边权和),若比min小更新min

4.合并最后扩展的那条边的两个端点为一个顶点(当然他们的边也要合并,这个好理解吧?)

5.转到2,合并N-1次后结束

6.min即为所求,输出min

prim本身复杂度是O(n^2),合并n-1次,算法复杂度即为O(n^3)

如果在prim中加堆优化,复杂度会降为O((n^2)logn)

这个Stoer-Wagner算法可以参见这篇paper(http://docs.google.com

/fileview?id=0BwxLvD9mcDNtMjk3MWVkMTAtZjMzNi00ZWE3LTkxYjQtYTQwNzcyZTk3Njk2&hl=en),

其核心思想是迭代缩小规模, 算法基于这样一个事实:

对于图中任意两点s和t, 它们要么属于最小割的两个不同集中, 要么属于同一个集.

如果是后者, 那么合并s和t后并不影响最小割. 基于这么个思想, 如果每次能求出图中某两点之间的最小割, 然后更新答案后合并它们再继续求最小割, 就得到最终答案了. 算法步骤如下:

1. 设最小割cut=INF, 任选一个点s到集合A中, 定义W(A, p)为A中的所有点到A外一点p的权总和.

2. 对刚才选定的s, 更新W(A,p)(该值递增).

3. 选出A外一点p, 且W(A,p)最大的作为新的s, 若A!=G(V), 则继续2.

4. 把最后进入A的两点记为s和t, 用W(A,t)更新cut.

5. 新建顶点u, 边权w(u, v)=w(s, v)+w(t, v), 删除顶点s和t, 以及与它们相连的边.

6. 若|V|!=1则继续1.

看起来很简单, 每次像做最大生成树一样选最大"边"(注意, 这里其实不是边, 而是已经累计的权值之和, 就当是加权的度好了),

然后把最后进入的两个点缩到一块就可以了. 合并点最多有n-1次, 而不加堆优化的prim是O(n^2)的, 所以最终复杂度O(n^3),

要是你有心情敲一大坨代码, 还可以在稀疏图上用Fibonacci Heap优化一下, 不过网上转了一圈, 大多都是说能用Fibonacci

Heap优化到怎样怎样的复杂度, 真正能自己写出来的恐怕也没几个, 看看uoregon(俄勒冈大学)的一大坨代码就有点寒.

(http://resnet.uoregon.edu/~gurney_j/jmpc/fib.html)

特别注意几个地方, 网上的好几个Stoer-Wagner版本都存在一些小错误:

1. 算法在做"最大生成树"时更新的不是普通意义上的最大边, 而是与之相连的边的权值和, 当所有边都是单位权值时就是累计度.

2. "最后进入A的两点记为s和t", 网上对s有两种解释, 一是在t之前一个加进去的点, 二是t的前趋节点, 也就是最后选择的那条边的另一端. 正解是第一种!

3. 对于稠密图, 比如这题, 我用堆, 映射二分堆, 或者STL的优先队列都会TLE, 还不如老老实实O(n^3).

POJ 2914模板

//就是最小割集,可以使用最小割 Stoer-Wagner 算法//题意就是要去掉一些边,使得可以分成两个集合,并且使得去掉的边的权值和为最小/*算法步骤:

1. 设最小割cut=INF, 任选一个点s到集合A中, 定义W(A, p)为A中的所有点到A外一点p的权总和.

2. 对刚才选定的s, 更新W(A,p)(该值递增).

3. 选出A外一点p, 且W(A,p)最大的作为新的s, 若A!=G(V), 则继续2.

4. 把最后进入A的两点记为s和t, 用W(A,t)更新cut.

5. 新建顶点u, 边权w(u, v)=w(s, v)+w(t, v), 删除顶点s和t, 以及与它们相连的边.

6. 若|V|!=1则继续1.*/

const int N = 501;const int MAXV = 0x3F3F3F3F;int n,m,v[N];//经过合并后的第i个节点v[i]

intmat[N][N];int dis[N];//dis[i]表示w(A,v[i])

boolvis[N];intres;

inlineint min(int a, intb){return a < b ?a : b;

}int Stoer_Wagner(intn) {inti, j;int res =MAXV;for (i = 0; i < n; i++)

v[i]= i;//初始化第i个结点就是i

while (n > 1) {int maxp = 1,prev = 0;for (i = 1;i < n;i++){ //初始化到已圈集合的割大小,并找出最大距离的顶点

dis[v[i]] = mat[v[0]][v[i]];if (dis[v[i]] >dis[v[maxp]])

maxp=i;

}

memset(vis,0, sizeof(vis));

vis[v[0]] = true;for (i = 1;i < n;i++) {if (i == n - 1){ //只剩最后一个没加入集合的点,更新最小割

res =min(res,dis[v[maxp]]);for (j = 0; j < n; j++){ //合并最后一个点以及推出它的集合中的点

mat[v[prev]][v[j]] +=mat[v[j]][v[maxp]];

mat[v[j]][v[prev]]=mat[v[prev]][v[j]];

}

v[maxp]= v[--n];//第maxp个节点去掉,第n个节点变成第maxp个

}

vis[v[maxp]]= true;

prev=maxp;

maxp= -1;for (j = 1;j < n;j++)if (!vis[v[j]]){ //将上次求的maxp加入集合,合并与它相邻的边到割集

dis[v[j]] +=mat[v[prev]][v[j]];if (maxp == -1 || dis[v[maxp]]

maxp=j;

}

}

}returnres;

}intmain(){while (scanf("%d%d", &n, &m) !=EOF) {

memset(mat,0, sizeof(mat));intx,y,z;while (m--) {

scanf("%d%d%d", &x, &y, &z);

mat[x][y]+=z;

mat[y][x]+=z;

}

printf("%d\n",Stoer_Wagner(n));

}return 0;

}

下行法求最小割集案例_无向图求最小割集相关推荐

  1. 下行法求最小割集案例_机械产品典型失效分析案例

    原标题:机械产品典型失效分析案例 长期以来,机械结构设计习惯于传统的静强度设计,然而实际工作中,多数机械产品不属于静载工作范畴.大量的产品失效案例表明,百分之70以上的产品失效属于疲劳问题,另外有百分 ...

  2. 不动点求数列通项原理_不动点法求数列的通项.pdf

    维普资讯 厂-m.一簸 ||.- l_¨ |≯|蠢嚣.| < 日 § 数 列 的通 项 一 杭州外国语学校 徐国君 文[1]中提出了一种称为 "常数消去法"妙求形如 3 不动 ...

  3. matlab求两向量夹角_【求精干货】高中数学知识点总结归纳高一学生必须掌握

    高中数学高考知识点总结高一必高中数学高一的学生离高考还有两年的时间,别看这两年感觉很长,其实时间一晃就过了,高中数学学习成绩不太好的同学该加油好好学习了.别等到最后一年累死累活的搞,还不一定有效果,今 ...

  4. python求三角形面积步骤_通过求三角形面积步入python程序世界.pdf

    通过求三角形面积步入python程序世界 第一章 通过求三角形面积步入 Python 程序世界 本章通过一个求三角形面积的案例带领读者快速进入 Python 世界,案例涉及一些编程必 须知道的内容,包 ...

  5. js求两圆交点_谈谈求线段交点的几种算法(js实现,完整版)

    "求线段交点"是一种非常基础的几何计算, 在很多游戏中都会被使用到. 下面我就现学现卖的把最近才学会的一些"求线段交点"的算法总结一下, 希望对大家有所帮助. ...

  6. python辗转相除法求最大公约数最小公倍数_辗转相除法求最大公约数/最小公倍数...

    http://blog.csdn.net/jtujtujtu/article/details/4407171 2009 辗转相除法求最大公约数: 辗转相除法, 又名欧几里德算法(Euclidean a ...

  7. python海伦公式求三角形面积程序流程图_《求三角形面积程序代码实现》教学设计...

    一.教学目标: 1 .能说出能否构成三角形的条件,并了解其 VB 表达式:能读懂求解三角形面积的程序流程图: 2 .了解编写程序代码的一般步骤,了解变量定义, IF 语句的基本语法格式: 3 .掌握 ...

  8. 复合函数求导经典例题_复合函数求导练习试题.doc

    WORD格式可编辑 专业技术资料整理分享 复合函数求导练习题 一.选择题(共26小题) 1.设,则f′(2)=( ) A.B.C.D. 2.设函数f(x)=g(x)+x+lnx,曲线y=g(x)在点( ...

  9. 不动点求数列通项原理_不动点求数列通项的原理

    求用不动点的原理,求数列通项的例子 数列中,A1=1,A2=2,A(n+2)=-A(n+1)+2An (A后的括号代表下标)求An通项 这道体我当时记了个方法:原式变形后 A(n+2)+A(n+1)- ...

  10. 不动点求数列通项原理_不动点求数列通项的原理是什么?

    匿名用户 1级 2011-08-30 回答 数列中,A1=1,A2=2, A(n+2)=-A(n+1)+2An (A后的括号代表下标)求An通项 这道体我当时记了个方法:原式变形后 A(n+2)+A( ...

最新文章

  1. Asp.net MVC2.0系列文章-MVC简介篇
  2. Mac OS X下安装和配置Maven
  3. 爬虫多线程生产者与消费者
  4. python tkinter控件_Python3 tkinter基础 Label pack 设置控件在窗体中的位置
  5. Atitit 软件体系重要理论学科 v2 s67.docx Atitit 软件重要理论学科 目录 1. 计算理论这门学问 2 1.1. 学科的产生 2 1.2. 在这些领域中,自动机理论和形式语言理论
  6. 降本增效利器!趣头条 Spark Remote Shuffle Service 最佳实践
  7. 快速利用第三方平台SDK,实现点对点语音通话
  8. matlab神经网络原理应用实例pdf,MATLAB神经网络原理与实例精解
  9. 趣味CSS3(一)--旋转的大风车
  10. text 热敏打印机_GitHub - huangzhiyi/thermal_printer: Java实现网络小票打印机自定义无驱打印...
  11. 数据库系统管理(选择 记录)
  12. 解决:kubeadm init K8S初始化报错02
  13. 服务器经常被攻击怎么办
  14. 一则软件需求有关的漫画
  15. app接口设计之signature签名的php实现
  16. openlayers中使用rBush(R树)来存放要素等信息,本文修改了一点其中的rbush源码中的demo,使用canvas画出了insert和delete操作(建立树和删除树中数据)
  17. 一种相对高效的按键消抖方法
  18. 如何制作自己的系统镜像以及备份管理
  19. 常见的图像文件格式又有哪些呢?
  20. 深入理解MVC分层模式

热门文章

  1. Velocity的使用
  2. node.js接入微信公众号开发
  3. android与ios设计规范,Android和ios设计规范
  4. php pos机刷卡,POS机刷卡的正确使用方法和注意事项
  5. Html 中的Body 标签
  6. 厨师服识别yolov5明厨亮灶
  7. 小米路由器4A千兆版c341编程器刷breed.bin详细教程
  8. python京东预约抢购_python 脚本实现京东抢购
  9. 开机出现grub rescue,修复办法
  10. 范浩强树的学习历程,同时附加一个例题HDU4585shaolin