图论小专题C
3 负环及其应用
3.1 判定算法
判断负环只能用“边松弛”算法,也就是Bellman-Ford和SPFA算法。这两个算法都是\(O(NM)\)级别的。因为负环中一定存在一条负边,使得\(dis_i > dis_j+d(i,j)\)恒成立。因此,在用边松弛算法时,如果一条边被松弛超过一定次数,我们就可以判定图中存在负环。负环则代表环上的边权和小于0。在负环上走若干圈,则\(dis_i\)可以趋近\(-\infty\)。
Bellman-Ford算法
如果经过\(n\)轮迭代后,仍然有边可以被更新,则图中存在负环。
否则,如果在\(n-1\)轮迭代后,如果不能更新任何一条边,则图中不存在负环。
SPFA算法
设\(|\Gamma_i|\)表示从源点到\(i\)的最短路包含的边数。规定\(|\Gamma_S|=0\)。当转移\(dis_y = dis_x + d(x,y)\)成立时,我们同时令\(|\Gamma_y| = |\Gamma_x| + 1\)。在任意时刻,如果有\(|\Gamma_y| \geq n\),则图中有负环。
我们也可以用入队次数来判断。如果一个节点被入队\(n\)次以上,则图中存在负环。
当然,前面也介绍过一种基于DFS的SPFA判断负环的方法。这种方法速度较快,但是比较专一。在计算最短路时,效率远不如基于队列的SPFA。
3.2 应用
其实比较灵活。只介绍一些比较简单的应用
图上二分
极少数题目会出现。由于本人做题不多,这里只能给出一道例题:HNOI2009 最小圈。
由于答案具有单调性——即不存在小于答案的平均值,而一定存在大于等于答案的平均值,我们可以二分求出最小值。设这个平均值为\(\bar{w}\),那么根据平均值的性质,对于环上的边\(w_i\),有\(\sum_{i=1}^{0}(w_i-\bar{w})=0\)。我们二分这个平均值\(\bar{w}\),然后把每条边的边权设置为\(w_i-\bar{w}\)。如果图中存在一个负环,说明当前平均值合法,可以进一步缩小。时间复杂度可以看作\(\Omega(m\log W)\)。当然,最坏情况还是\(O(nm\log W)\)的。其中\(W\)表示边权的上下界之差。
差分约束系统
是一种特殊的\(N\)元一次不等式组。其中每一个不等式都形如\(X_i - X_j \leq c_k\)。通过移项,我们可以得到一个不等式:\(X_i \leq X_j + c_k\)。这个不等式酷似我们之前所讲到的三角形不等式。我们的目标就是求出一组\(X_i\)使得每一个三角形不等式成立。对于\(X_i - X_j \geq c_k\)的不等式,可以转换为\(X_j - X_i \leq -c_k\)的形式解决。
注意到如果\(\{X_i\}\)是一组解,那么通过加上一个常数\(c\),我们可以得到另一组解\(\{X_i+c\}\)。我们不妨假定每一个变量都是负数或0,设\(X_0 = 0\),令\(X_i \leq 0\),则\(X_i - X_0 \leq 0\)。我们由\(X_0\)向所有点连一条边权为0的边,然后对于所有\(X_i - X_j \leq c_k\)的边,我们往\(j\)从\(i\)连一条边。这时,\(X_i\)的实际意义就是从\(0\)点到\(i\)点的最短距离。用最短路算法就可以求出一组负数解。
当构造出来的图中存在负环,\(X_i\)会被不断更新:说明\(X_i\)的值始终无法满足每个不等式。此时这个差分约束系统无解。由于既要求出最短路,又要判断负环,这里应该使用SPFA。
图论小专题C的更多相关文章
- 图论小专题A
大意失荆州.今天考试一到可以用Dijkstra水过的题目我竟然没有做出来,这说明基础还是相当重要.考虑到我连Tarjan算法都不太记得了,我决定再过一遍蓝皮书,对图论做一个小的总结.图论这个部分可能会 ...
- 图论小专题B
2 树 2.1 树的定义 一个只有\(N-1\)条边,且任意两个点连通的图叫做树.通过这样定义的树往往是一棵无根树,而我们通常会任意选定一个根节点使其变成有根树.有根树可以定义"父亲和儿子& ...
- NOIp 图论算法专题总结 (1):最短路、最小生成树、最近公共祖先
系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 最短路 Floyd 基本思路:枚举所有点与点的中点,如果从中点走最短,更新两点间 ...
- 【总结】图论小总结【题解】P1330封锁阳关大学
[题解][总结]P1330 封锁阳光大学 &&图论小总结 这道题其实有一点点难度,不过我能经过思考做出来说明还是没有普及组\(D1T1\)难度的. 考虑一条边的两边要有且仅有一个点被选 ...
- NOIp 图论算法专题总结 (2)
系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 树链剖分 https://oi-wiki.org/graph/heavy-lig ...
- NOIp 图论算法专题总结 (3):网络流 & 二分图 简明讲义
系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 网络流 概念 1 容量网络(capacity network)是一个有向图,图的 ...
- 「日常训练」「小专题·图论」Domino Effect(1-5)
题意 分析 这题几乎就是一条dijkstra的问题.但是,如何考虑倒在中间? 要意识到这题求什么:单源最短路的最大值.那么有没有更大的?倒在中间有可能会使它更大. 但是要注意一个问题:不要把不存在的边 ...
- 「日常训练」「小专题·图论」 Cow Contest (1-3)
题意 分析 问题是要看出来这是个floyd闭包问题.我没看出来- - 分析之后补充. 代码 // Origin: // Theme: Graph Theory (Basic) // Date: 080 ...
- 「日常训练」「小专题·图论」 Frogger (1-1)
题意 分析 变形的dijkstra. 分析题意之后补充. 代码 // Origin: // Theme: Graph Theory (Basic) // Date: 080518 // Author: ...
随机推荐
- 树链剖分 树剖求lca 学习笔记
树链剖分 顾名思义,就是把一课时分成若干条链,使得它可以用数据结构(例如线段树)来维护 一些定义: 重儿子:子树最大的儿子 轻儿子:除了重儿子以外的儿子 重边:父节点与重儿子组成的边 轻边:除重边以外 ...
- Centos7下永久修改mysql5.6最大连接数
由于解除系统限制,设置最大连接数时,量力而行.https://blog.csdn.net/five3/article/details/79671317
- go的命令行参数
package main import ( "fmt" "os" ) func main() { var s, sep string for i := 1; i ...
- Spring集成kafka,消费者运行时内存占用会一直增长
Spring集成kafka,消费者运行时内存占用会一直增长? 20C 本人用Spring集成kafka消费者,发布运行时内存占用会一直升高,最后程序挂掉.请各位大神看看,提供解决方法 以下是我的配置文 ...
- .NET webapi 的单元测试
public abstract class MirAPIUnitTestCommon { public abstract string GetBaseAddress(); /// <summar ...
- 如何在调用Marketing Cloud contact创建API时增加对扩展字段的支持
需求:扩展字段"微信ID"是我创建出来的extension field,我想用Marketing Cloud提供的contact creation API,在创建contact时也 ...
- validform 自定义校验
validform虽然很强大,但是依然不能满足我们各种奇葩的校验,这是时候就需要我们自己去手写. vaildform 也是基于jq的,正常我们需要引入5个文件 supply 是我们自定义方法的js文件 ...
- 【atcoder】GP 2 [agc036C]
题目传送门:https://atcoder.jp/contests/agc036/tasks/agc036_c 题目大意:给你一个长度为$N$初始全0的序列,每次操作你可以找两个不同的元素,一个自增1 ...
- vim学习(一)
vim是linux和mac中常用到的编辑器. 其分为4种模式: normal模式:普通模式,浏览作用 insert模式: i(insert) 在当前光标处进行插入 a(append) 在当前光 ...
- SELinux 了解及CentOS7 中 semanage命令的安装
SELinux 安全子系统 SELinux(Security-Enhanced Linux)是美国国家安全局在Linux开源社区的帮助下开发的一个强制访问控制(MAC,Mandatory Access ...