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的更多相关文章

  1. 图论小专题A

    大意失荆州.今天考试一到可以用Dijkstra水过的题目我竟然没有做出来,这说明基础还是相当重要.考虑到我连Tarjan算法都不太记得了,我决定再过一遍蓝皮书,对图论做一个小的总结.图论这个部分可能会 ...

  2. 图论小专题B

    2 树 2.1 树的定义 一个只有\(N-1\)条边,且任意两个点连通的图叫做树.通过这样定义的树往往是一棵无根树,而我们通常会任意选定一个根节点使其变成有根树.有根树可以定义"父亲和儿子& ...

  3. NOIp 图论算法专题总结 (1):最短路、最小生成树、最近公共祖先

    系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 最短路 Floyd 基本思路:枚举所有点与点的中点,如果从中点走最短,更新两点间 ...

  4. 【总结】图论小总结【题解】P1330封锁阳关大学

    [题解][总结]P1330 封锁阳光大学 &&图论小总结 这道题其实有一点点难度,不过我能经过思考做出来说明还是没有普及组\(D1T1\)难度的. 考虑一条边的两边要有且仅有一个点被选 ...

  5. NOIp 图论算法专题总结 (2)

    系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 树链剖分 https://oi-wiki.org/graph/heavy-lig ...

  6. NOIp 图论算法专题总结 (3):网络流 & 二分图 简明讲义

    系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 网络流 概念 1 容量网络(capacity network)是一个有向图,图的 ...

  7. 「日常训练」「小专题·图论」Domino Effect(1-5)

    题意 分析 这题几乎就是一条dijkstra的问题.但是,如何考虑倒在中间? 要意识到这题求什么:单源最短路的最大值.那么有没有更大的?倒在中间有可能会使它更大. 但是要注意一个问题:不要把不存在的边 ...

  8. 「日常训练」「小专题·图论」 Cow Contest (1-3)

    题意 分析 问题是要看出来这是个floyd闭包问题.我没看出来- - 分析之后补充. 代码 // Origin: // Theme: Graph Theory (Basic) // Date: 080 ...

  9. 「日常训练」「小专题·图论」 Frogger (1-1)

    题意 分析 变形的dijkstra. 分析题意之后补充. 代码 // Origin: // Theme: Graph Theory (Basic) // Date: 080518 // Author: ...

随机推荐

  1. kafka安装、相关命令以及PHP使用

    1.安装JAVA #下载安装包 https://www.oracle.com/technetwork/java/javase/downloads/index.html tar -xzvf jdk-8u ...

  2. Class.getResources()和classLoader.getResources()区别

    Class.getResource(String path) path不以’/'开头时,默认是从此类所在的包下取资源: path 以’/'开头时,则是从ClassPath根下获取: package t ...

  3. .Net C# interface使用

    using System; using System.ServiceModel; namespace com._80community.unittest.Demo { public delegate ...

  4. python 比对PDF文件

    基本思路: 1.读取pdf内容,存放到不同的 list 2.比较 list 的相似度 ------------------------ 实现------------------------- 1.PD ...

  5. C#从服务器下载文件的四种方式

    //方法一:TransmitFile实现下载 string fileName = "ss.docx"; //客户端预设的文件名,导出时可修改  string filePath = ...

  6. IOS 点击按钮拨号

    - (IBAction)OnTouch_bHotLine:(id)sender { [[UIApplication sharedApplication] openURL:[NSURL URLWithS ...

  7. String Class

    #include <iostream> #include <fstream> #include <sstream> using namespace std; tem ...

  8. 一个下午整理的Web前端常见的英文缩写

    PV (Page View)页面浏览量 FED(Front-End Development)前端开发 F2E(Front-End Engineer)前端工程师 WWW(World Wide Web)万 ...

  9. element消息提示封装

    官方的 <template> <el-button :plain="true" @click="open2">成功</el-but ...

  10. mysql authentication plugin 'caching_sha2_password'

    解决办法: ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root1';