匈牙利算法

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

 

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

技术分享

 

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

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

技术分享

 

技术分享

 

流程图

技术分享

 

伪代码:

 

演示:

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

 

C实现(作者BYVoid

Pascal实现(作者魂牛

 

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

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。