匈牙利算法(Kuhn-Munkres)算法

个人感觉匈牙利算法(KM算法)并不好理解,想搞懂需要花一些时间。如果只是想用,那直接使用Matlab版本的链接里的代码即可

 

几个非常有用的连接:

1  https://www.topcoder.com/community/data-science/data-science-tutorials/assignment-problem-and-hungarian-algorithm/#!

2  http://hungarianalgorithm.com/examplehungarianalgorithm.php

3  http://csclab.murraystate.edu/~bob.pilgrim/445/munkres.html

链接1是一种实现方式,链接2,3是从另外一种角度实现的

Matlab 代码实现:  https://cn.mathworks.com/matlabcentral/fileexchange/20328-munkres-assignment-algorithm

此matlab版本是链接2,3的一种实现

Python 代码实现:  https://pypi.python.org/pypi/munkres/1.0.5.4   (此版本本人未使用过)

补充:

4    一篇不错的文档 点这里  ,配上这里的博客看,点这里 

 

 

 

以下内容摘自高随祥的《图论与网络流理论》一书

 

                |N(S)|或者|X|或|Y|表示的是相应集合的元素的个数。

                N(S)表示与S集合中的顶点相邻接的顶点,例如,A-B-C-D中,B的邻接点就是A和C。

       A-B-C-D是一条增广路,红色线表示属于M匹配,黑色线表示不属于,图中,B,C两点是M饱和的,A,D两点是非M饱和的。

 

 

 

 

 

       上面这个算法只是针对饱和X的,意思就是,如果X中的每个顶点都已匹配上,那么算法终止,而不必管Y中的顶点是否都有匹配。

                 圆圈里面一个加号的运算其实可以简单理解为增广路的取反,所谓取反就是把属于M匹配的边变成不属于M的边,把不属于M的边变为属于M的边,在那个A-B-C-D的增广路的图例中就是把A-B和C-D边变成红色而把B-C边变成黑色。这样做一个明显的作用就是匹配的边数增多了一条!

 

 

 

 

       下面是求二部图最大匹配的匈牙利算法,就是不管X还是Y,我们求得是含匹配边最多的匹配

 

 

 

       一般的,我们会这样取顶点标号的值:l(y)全部赋值为0,而l(x)取得是和顶点x相邻接的所有的点之间的权重的最大值。下面有个例子用的就是这个方法。

 

 

      “图G的平凡标号”那个图上X集中的各顶点上的数字5,2,4,1就是顶点标号,Y集中的顶点标号全为0。

 

 

       上面这个修改标号的过程是KM算法区别于匈牙利算法的地方。修改的目的是在目前找到的M匹配的基础上增加可行顶点,从而得到增广路。

 

 

 

 

 

  • 43
    点赞
  • 189
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Kuhn-Munkres算法,也被称为匈牙利算法或是匹配算法,是一种用于解决二分图最大权匹配问题的经典算法。该算法被广泛应用在如任务分配、资源分配、指派问题等场景中。 在Matlab中,我们可以使用以下的步骤来实现Kuhn-Munkres算法: 1. 首先,我们需要将问题转化为一个二分图。比如,如果我们的问题是任务分配问题,那么我们可以用一个邻接矩阵来表示任务与资源之间的关系,其中矩阵的行表示任务,列表示资源,非零元素表示任务与资源之间的关系强度。 2. 接下来,我们需要定义一个函数来实现Kuhn-Munkres算法。函数的输入参数可以是我们定义好的邻接矩阵。在函数中,我们可以创建一个与邻接矩阵相同大小的全零矩阵,作为初始化的匹配集合。 3. 然后,我们可以将匹配问题转化为一个最大权完备匹配问题。这可以通过对邻接矩阵进行转换来实现。比如,我们可以对邻接矩阵的每一行进行减法操作,保留每行的最大值。 4. 在算法的主循环中,我们需要不断地找到最佳的匹配,并更新匹配集合。具体来说,我们可以从邻接矩阵中选择一个最高权值的未匹配点开始,然后通过一系列的增广路径来找到增广路径树。通过更新匹配集合,我们将已匹配点标记为匹配,未匹配点标记为未匹配,并继续寻找下一个未匹配点。直到无法找到更多增广路径为止。 5. 最后,我们可以返回匹配集合和最大权值。根据应用的不同,我们可以使用这些信息来解决具体的问题。 总之,Kuhn-Munkres算法是一种在Matlab中实现的二分图最大权匹配算法。通过将问题转化为二分图,定义函数并实现算法的主要步骤,我们可以使用Matlab来解决各种应用场景中的最大权匹配问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值