匈牙利算法

 本文转自大牛博客:http://www.byvoid.com/blog/hungary/

 

这是一种用增广路求二分图最大匹配的算法。它由匈牙利数学家Edmonds于1965年提出,因而得名。 定义 未盖点:设Vi是图G的一个顶点,假设Vi 不与随意一条属于匹配M的边相关联,就称Vi 是一个未盖点。

匈牙利算法

 

交错路:设P是图G的一条路,假设P的随意两条相邻的边一定是一条属于M而还有一条不属于M,就称P是一条交错路。

可增广路:两个端点都是未盖点的交错路叫做可增广路。

匈牙利算法

 

匈牙利算法

 

流程图

l

 

伪代码:

 

演示:

1

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

匈牙利算法

 

C实现(作者BYVoid

Pascal实现(作者魂牛

 

ps:近期由于比赛,须要用到二分图,图论这东西好多要好好学的。

 

你可能感兴趣的:(算法)