网络流简介
本页面主要介绍网络流相关的基本知识。
概述
网络(network)是指一个特殊的有向图
中的每条边 都有一个被称为容量(capacity)的权值,记作 。当 时,可以假定 。 中有两个特殊的点:源点(source) 和汇点(sink) ( )。
对于网络
- 容量限制:对于每条边,流经该边的流量不得超过该边的容量,即
; - 流守恒性:除源汇点外,任意结点
的净流量为 。其中,我们定义 的净流量为 。
对于网络
对于网络
常见问题
常见的网络流问题包括但不限于以下类型问题。
- 最大流问题:对于网络
,给每条边指定流量,得到合适的流 ,使得 的流量尽可能大。此时我们称 是 的最大流。 - 最小割问题:对于网络
,找到合适的 - 割 ,使得 的容量尽可能小。此时我们称 是 的最小割。 - 最小费用最大流问题:在网络
上,对每条边给定一个权值 ,称为费用(cost),含义是单位流量通过 所花费的代价。对于 所有可能的最大流,我们称其中总费用最小的一者为最小费用最大流。
我们将在稍后的章节中对它们进行详细介绍。
例题:网络流 24 题
网络流 24 题是中文互联网上广泛流传的一个题单(LibreOJ/洛谷),至少在 2010 年前后就已经存在。该题单引入了一些经典的将其他问题建模为网络流问题的技巧。由于时代的局限性,这些问题未必是最具代表性的网络流问题,但仍值得有志于算法竞赛的读者一阅。
本页面最近更新:2024/1/28 02:02:59,更新历史
发现错误?想一起完善? 在 GitHub 上编辑此页!
本页面贡献者:Anguei, Chrogeek, EndlessCheng, Enter-tainer, Ir1d, Macesuted, MegaOwIer, MingqiHuang, Nanarikom, ouuan, sshwy, StudyingFather, Tiphereth-A, Xarfa, Xeonacid
本页面的全部内容在 CC BY-SA 4.0 和 SATA 协议之条款下提供,附加条款亦可能应用