博客
关于我
[学习笔记] 最小割树
阅读量:1286 次
发布时间:2019-03-05

本文共 966 字,大约阅读时间需要 3 分钟。

最小割树的构建与性质

在学习图论时,了解最小割树是一个非常有用的知识点。它用于解决一个图中两个点之间的最小割问题。虽然这在实际应用中可能不太常见,但从理论上讲,它是一个非常有趣且有趣的知识点。

最小割树的构建

最小割树的构建采用分治法。首先,随便选择两个点x和y,计算它们之间的最小割。将这条最小割的边添加到最小割树上,这样原图就被分割成了两个连通块,记为Vx和Vy。接下来,我们记录每个点属于哪个连通块,然后递归地对每个连通块重复同样的过程。

这种分治策略确保了我们最终能够构建一棵包含所有点的最小割树。每次分割都减少了问题规模,直到只剩下一个点为止。这样,整个过程就覆盖了所有点,确保了最小割树的完整性。

最小割树的性质

最小割树的最重要性质是:树上任意两点之间的路径边权的最小值,就是原图上这两点之间的最小割。为了更好地描述,我们记λ(a,b)为点a和点b之间的最小割。

定理1

对于Vx中的点a和Vy中的点b,有λ(a,b) ≤ λ(x,y)。证明过程简单明了,因为x和y的最小割将a和b分割开来,而a和b的最小割不可能比x和y的大。

定理2

对于任意三点a、b、c,有λ(a,b) ≥ min(λ(b,c), λ(a,c))。如果λ(a,b)不是这两个值中的最小值,那么它会被其中一个所限制。

定理3

在最小割树上的一条路径(x,y),路径上最小的最小割就是λ(a,b),其中a和b是在这条路径上的点。证明过程结合定理2,说明路径上的最小割不可能超过λ(x,y),同时因为构造过程,λ(x,y)也不可能比λ(a,b)小,因此两者相等。

例题

例题部分的数据似乎没有问题,但没有具体的数据,可能会影响实际应用和验证。这需要确保例题的数据完整,才能进行有效的练习和验证。

代码实现

代码实现了使用网络流算法来求解最小割,然后构建最小割树。代码中定义了边的结构,使用了BFS和DFS来计算最大流,进而求解最小割。然后,通过递归的solve函数构建最小割树,pre函数用于预处理LCA信息。lca函数用于计算两点的最低公共祖先,可能在构建最小割树时用到。

总结

虽然代码看起来复杂,但大致的思路是先构建最小割树,然后通过预处理和LCA来快速查询最小割。虽然目前不太确定代码的具体实现细节,但通过学习和理解,相信会逐渐掌握这一技术。

转载地址:http://jcozz.baihongyu.com/

你可能感兴趣的文章
pandas 数据框将 INT64 列转换为布尔值
查看>>
pandas 数据框将列类型转换为字符串或分类
查看>>
pandas 数据框条件 .mean() 取决于特定列中的值
查看>>
pandas 数据框至海运分组条形图
查看>>
Pandas 数据透视表:列顺序和小计
查看>>
pandas 时序统计的高级用法!
查看>>
pandas 时间序列重新采样结束给定的一天
查看>>
pandas 根据不是常量的第三列的值将值从一列复制到另一列
查看>>
pandas 根据值从多列中的一列查找
查看>>
Pandas 根据布尔条件选择行和列
查看>>
pandas 滚动窗口 - datetime64[ns] 未实现
查看>>
pandas 版本兼容特定的蟒蛇和NumPy配置吗?
查看>>
pandas 生成excel多级表头
查看>>
Pandas 的 DataFrame 详解-ChatGPT4o作答
查看>>
pandas 读取excel数据,以字典形式输出
查看>>
Pandas 读取具有浮点值的 csv 文件会导致奇怪的舍入和小数位数
查看>>
pandas 适用,但仅适用于满足条件的行
查看>>
pandas 重新采样到每月的特定工作日
查看>>
pandas :如何删除以NaN为列名的多个列?
查看>>
pandas :我如何对堆叠的条形图进行分组?
查看>>