我找到的唯一能看懂的题解:【ZZ】最小割集Stoer-Wagner算法

似乎是一个冷门算法,连oi-wiki上都没有,不过洛谷上竟然有它的模板题,并且2017百度之星的资格赛还考到了。于是来学习一下。

一些定义

无向图的(全局)最小割:一个边权和最小的边集,断掉后图不联通。

算法

我们自然可以直接钦定一个 \(S\),枚举 \(T\),求最小割,其中最小值即为答案。不过复杂度过于高,大概是 \(O(n^3m)\),当遇到稠密图的时候,就是 \(O(n^5)\)。(尽管这个复杂度非常虚,靠信仰或许能通过题)如果我们用最小割树,复杂度不会变。因此我们需要一个更快捷的方法。

流程

(没写证明是因为不会证明)

设 \(w[p]\) 表示点集外一点 \(p\) 到当前维护的点集中所有点的权值和(类似加权度数)。

  1. 找到当前图中 \(w[p]\) 最大的点 \(p\),将 \(p\) 加入到当前集合,并更新其它 \(w[p]\)。

  2. 若集合不为全集,则重复 1 操作。

  3. 设最后加入点集的两点为 \(s, t\)(..., \(s\), \(t\)),最后的 \(w[t]\) 即为 \(s, t\) 的最小割。用此最小割更新答案,并合并 \(s, t\).

  4. 若当前点数仍大于2,则清空集合,回到 1 操作。

由此可知,SW 算法的复杂度是 \(O(n^3)\)。

关键代码

使用邻接矩阵更方便。

int v[N][N], w[N], s, t;//邻接矩阵,加权度数,源汇
bool del[N], vis[N];//是否因合并被删除,是否在点集里
inline int search() {//将点逐个加入点集,得到s,t,s-t最小割
memset(w, 0, sizeof(w));
memset(vis, 0, sizeof(vis));//清空集合
s = 0, t = 0;
int res = inf;
while(1) {
int p = 0, mx = -inf;
for (register int i = 1; i <= n; ++i) if (!del[i] && !vis[i])
if (w[i] > mx) mx = w[i], p = i;
vis[p] = true;
if (!p) return res;//没有点集以外的点了
s = t, t = p;
res = w[p];
for (register int i = 1; i <= n; ++i) if (!del[i] && !vis[i])
w[i] += v[i][p];
}
}
inline void SW() {//更新答案,合并
int ans = inf;
for (register int i = 1; i < n; ++i) {
MIN(ans, search());
if (!ans) break;
del[t] = true;
for (register int j = 1; j <= n; ++j) if (!del[j]) {
v[s][j] += v[t][j];
v[j][s] += v[j][t];//无向图合并
}
}
printf("%d\n", ans);
}

感性理解

博客里说和 prim 算法有关系,但是我并不精通 prim 算法,因此理解起来会很费劲。

现在我要发挥shadowice精神了

纯属口胡,无任何逻辑。

\(w[p]\) 为 \(p\) 到点集的“加权度数”,可以衡量 \(p\) 与点集的“紧密度”。我们每次首先选择与点集“紧密度”更大的点加入点集,最后加入的 \(s, t\) 就是与图“紧密度”最小的点了,因此 \(w[t]\) 是将 \(t\) 这个最“边远”的点割离图的最小费用。

如果 \(s, t\) 在最终的最小割中不在同一连通块,那么答案会被这一轮计算出来;如果 \(s, t\) 在同一连通块,那么合并 \(s, t\) 也对答案没有影响。

相关题目

P5632 【模板】Stoer-Wagner算法

模板题

hdu 3002 King of Destruction

模板题

hdu 6081 度度熊的王国战略

n <= 3000。尽管给了 20 秒,这道题仍然是不可做题。不过可以拿贪心水过。

SW算法求全局最小割(Stoer-Wagner算法)的更多相关文章

  1. poj 2914(stoer_wanger算法求全局最小割)

    题目链接:http://poj.org/problem?id=2914 思路:算法基于这样一个定理:对于任意s, t   V ∈ ,全局最小割或者等于原图的s-t 最小割,或者等于将原图进行 Cont ...

  2. 求全局最小割(SW算法)

    hdu3002 King of Destruction Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (J ...

  3. 图的全局最小割的Stoer-Wagner算法及例题

    Stoer-Wagner算法基本思想:如果能求出图中某两个顶点之间的最小割,更新答案后合并这两个顶点继续求最小割,到最后就得到答案. 算法步骤: --------------------------- ...

  4. UVALive 5099 Nubulsa Expo 全局最小割问题

    B - Nubulsa Expo Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit S ...

  5. poj2914 Minimum Cut 全局最小割模板题

    Minimum Cut Time Limit: 10000MS   Memory Limit: 65536K Total Submissions: 8324   Accepted: 3488 Case ...

  6. HDU 6081 度度熊的王国战略(全局最小割Stoer-Wagner算法)

    Problem Description 度度熊国王率领着喵哈哈族的勇士,准备进攻哗啦啦族. 哗啦啦族是一个强悍的民族,里面有充满智慧的谋士,拥有无穷力量的战士. 所以这一场战争,将会十分艰难. 为了更 ...

  7. HDU 6081 度度熊的王国战略(全局最小割堆优化)

    Problem Description度度熊国王率领着喵哈哈族的勇士,准备进攻哗啦啦族.哗啦啦族是一个强悍的民族,里面有充满智慧的谋士,拥有无穷力量的战士.所以这一场战争,将会十分艰难.为了更好的进攻 ...

  8. HDU 3691 Nubulsa Expo(全局最小割)

    Problem DescriptionYou may not hear about Nubulsa, an island country on the Pacific Ocean. Nubulsa i ...

  9. POJ 2914 Minimum Cut Stoer Wagner 算法 无向图最小割

    POJ 2914 题意:给定一个无向图 小于500节点,和边的权值,求最小的代价将图拆为两个联通分量. Stoer Wagner算法: (1)用类似prim算法的方法求"最大生成树" ...

随机推荐

  1. kubernetes资源均衡器Descheduler

    背景 Kubernetes中的调度是将待处理的pod绑定到节点的过程,由Kubernetes的一个名为kube-scheduler的组件执行.调度程序的决定,无论是否可以或不能调度容器,都由其可配置策 ...

  2. CSS定位(Positioning)

    CSS 定位和浮动 CSS 为定位和浮动提供了一些属性,利用这些属性,可以建立列式布局,将布局的一部分与另一部分重叠,还可以完成多年来通常需要使用多个表格才能完成的任务. 一切皆为框 div.h1 或 ...

  3. 数据库连接池 --Druid 连接工具类创建_JDBCUtils

    package com.itheima.jdbc_druid; import com.alibaba.druid.pool.DruidDataSourceFactory; import javax.s ...

  4. 119.杨辉三角II

    这道题和第118题是一样的,需要注意这道题目对行数的要求         # 定义一个列表,用来存放数据         num_list = []         for index1 in ran ...

  5. Python之浅谈绑定方法

    目录 绑定方法和非绑定方法 绑定方法 对象的绑定方法 类的绑定方法 非绑定方法 总结 绑定方法和非绑定方法 类中定义的方法大致可以分为两类:绑定方法和非绑定方法.其中绑定方法又可以分为绑定到对象的方法 ...

  6. Nginx功能详细介绍(大而全)

    Nginx介绍 Nginx是C语言开发的. HTTP和反向代理Web服务器. Nginx ⼜能做什么事情(应⽤场景) Http服务器(Web服务器) 性能⾮常⾼,⾮常注重效率,能够经受⾼负载的考验. ...

  7. .gitkeep文件

    git 默认不会对空文件夹进行追踪: 但某些项目某些文件夹对整体框架是必不可少的,就算是空也得有: 怎么办呢?在这个文件夹下添加一个[.gitkeep]文件,这样就可以同步该文件夹了. (完)

  8. Python3笔记004 - 2.1 python的语法特点

    第2章 python语言基础 python语法特点 保留字与标识符 变量 数据类型 运算符 输入和输出 2.1 python的语法特点 2.1.1 注释 注释的内容将被python解释器忽略,并不会在 ...

  9. Java中保留小数点后几位

    不想多说啥了..ε=(´ο`*)))唉  基础都给忘了..今天比赛 跌入十八层地狱.... 用DecimalFormat对象的format方法进行格式化.. package cn.test; impo ...

  10. 洛谷 P1433 吃奶酪 状压DP

    题目描述 分析 比较简单的状压DP 我们设\(f[i][j]\)为当前的状态为\(i\)且当前所在的位置为\(j\)时走过的最小距离 因为老鼠的坐标为\((0,0)\),所以我们要预处理出\(f[1& ...