跳转至

图匹配

匹配 或是 独立边集 是一张图中不具有公共端点的边的集合。 在二分图中求匹配等价于网路流问题。

图匹配算法是信息学竞赛中常用的算法,总体分为最大匹配以及最大权匹配,先从二分图开始介绍,再进一步提出一般图的作法。

图的匹配

在图论中,假设图 ,其中 是点集, 是边集。

一组两两没有公共点的边集 称为这张图的 匹配

定义匹配的大小为其中边的数量 ,其中边数最大的 最大匹配

当图中的边带权的时候,边权和最大的为 最大权匹配

匹配中的边称为 匹配边,反之称为 未匹配边

一个点如果属于 且为至多一条边的端点,称为 匹配点,反之称为 未匹配点

  • 极大匹配(maximal matching):无法再增加匹配边的匹配。不一定是最大匹配。
  • 最大匹配(maximum matching or maximum cardinality matching):匹配边数量最多的匹配。最大匹配可能有不止一个,但最大匹配的边数是确定的,而且不可能超过图中定点数的一半。
  • 最大权匹配(maximum weight matching):加权图中,权值和最大的匹配。
  • 最大权最大匹配(maximum weight maximum cardinality matching):匹配数最多的前提下,边权和最大的匹配。即所有最大匹配中,边权和最大的匹配。
  • 完美匹配(perfect matching):所有点都属于匹配,同时也符合最大匹配。若图 G 为完全图且顶点数为偶数时,必然存在完美匹配。
  • 近完美匹配(near-perfect matching):发生在图的点数为奇数,刚好只有一个点不在匹配中,扣掉此点以后的图称为 factor-critical graph。

    maximal matching

    maximal matching

    最大匹配

    maximum cardinality matching

    最大权匹配

    maximum weight matching

    最大权最大匹配

    maximum weight maximum cardinality matching

二分图匹配

bi-graph

一张二分图上的匹配称作二分匹配

为二分图,若在 的子图 中,任意两条边都没有公共节点,那么称 为二分图 的一个匹配,且 的边数为匹配数。

完美匹配

为二分图, 中一个最大匹配,且 ,则称 的完美匹配。

霍尔定理

设二分图 ,则 中存在 的完美匹配当且仅当对于任意的 ,均有 ,其中 ,是 的邻域。

最大匹配

寻找二分图边数最大的匹配称为最大匹配问题。

算法

组合优化中的一个基本问题是求 最大匹配(maximum matching)

二分图最大匹配

详见 二分图最大匹配 页面。

在无权二分图中,Hopcroft–Karp 算法可在 解决。

二分图最大权匹配

详见 二分图最大权匹配 页面。

在带权二分图中,可用 Hungarian 算法解决。 如果在最短路搜寻中用 Bellman–Ford 算法,时间复杂度为 , 如果用 Dijkstra 算法或 Fibonacci heap,可用 解决。

一般图最大匹配

详见 一般图最大匹配 页面。

无权一般图中,Edmonds' blossom 算法可在 解决。

一般图最大权匹配

详见 一般图最大权匹配 页面。

带权一般图中,Edmonds' blossom 算法可在 解决。

匹配算法的转换

用最大权最大匹配求最大权匹配

最大权最大匹配 允许负边权 ,但是 最大权匹配 不会有负边权。

若一张图 其所有的边皆为负权,则其 最大权匹配

调整边的权重

先将图 的所有负权边其权重 设为 ,再进行接下来的步骤。

完全图性质

当图 为完全图且没有负边权时,最大权最大匹配=最大权匹配

所以把图 铺成完全图,铺上的边其权重为 ,计算 最大权最大匹配 后再把权重为 0 的边去除即可。如下图所示。

graph-match

用最大权匹配求最大权最大匹配

最大权匹配 不会有负边权,且零边 可选可不选,但是 最大权最大匹配 允许负边权和零边。

调整边的权重

,若没有负边权和零边则 。把图 G 中所有的边其权重 加上 产生一张新图 。得到的新图 不存在负边权和零边。

最大权最大匹配 不一定等于 最大权匹配,但如果把所有边的边权加上一个足够大的数 最大权匹配 的结果就是 最大权最大匹配。这样的 应该取多大? 令 ,把图 G 中所有的边其权重 加上 ,产生一张新图

此时对图 G 进行 最大权匹配,其结果可以对应原图 最大权最大匹配。如下图所示。

graph-match

参考资料

  1. Wikiwand - Matching (graph theory)
  2. Wikiwand - Blossom algorithm
  3. 2015 年《浅谈图的匹配算法及其应用》- 陈胤伯
  4. 演算法笔记 - Matching
  5. the-tourist/algo
  6. Bill Yang's Blog - 带花树学习笔记
  7. 二分图的最大匹配、完美匹配和匈牙利算法
  8. Wikiwand - Hopcroft–Karp algorithm