Kuhn-Munkres算法

KM算法,求完备匹配下的最大权匹配,时间复杂度O(\(n^3\))

所谓的完备匹配就是在二部图中,x点集中的所有点都有对应的匹配 且 y点集中所有的点都有对应的匹配 ,则称该匹配为完备匹配

算法思想

(1)初始化可行顶标的值;

(2)用匈牙利算法寻找完备匹配;

(3)若未找到完备匹配则修改可行顶标的值;

(4)重复(2)(3)直到找到相等子图的完备匹配为止。

模板

#include <bits/stdc++.h>
using namespace std;
#define mem(a,b) memset(a,b,sizeof(a))
#define cin(a) scanf("%d",&a)
#define pii pair<int,int>
#define ll long long
#define gcd __gcd
const int inf = 0x3f3f3f3f;
const int maxn = 310;
const int M = 1e9+7;
int n,m,k,t; int a[maxn][maxn]; //图
int ex_x[maxn]; //x期望能匹配到的y值
int ex_y[maxn]; //y期望能匹配到的x值
bool vis_x[maxn]; //标记是否访问
bool vis_y[maxn]; //标记是否访问
int match[maxn]; //y的匹配
int slack[maxn]; //y的松弛,记录y最少还差多少期望值 bool dfs(int x)
{
vis_x[x] = 1;
for(int y = 0; y <= y; y++)
{
if(vis_y[y]) continue; int gap = ex_x[x]-ex_y[y]-a[x][y]; if(gap == 0) //如果符合要求
{
vis_y[y] = 1;
if(match[y] == -1 || dfs(match[y])) //如果y没有被匹配,或者y的x可以换另一个y
{
match[y] = x;
return true;
}
}
else //不符合要求,我还差gap的期望值才能有匹配
{
slack[y] = min(slack[y],gap);
}
}
} int km()
{
mem(match,-1);mem(ex_y,0); //y期望的x是0
mem(ex_x,0); //初始化
for(int i = 0; i < n; i++) //x期望的y是最大的那个
{
for(int j = 0; j < n; j++)
{
ex_x[i] = max(ex_x[i],a[i][j]);
}
} for(int i = 0; i < n; i++)
{
mem(slack,inf);
while (1)
{
mem(vis_x,0);mem(vis_y,0);
if(dfs(i)) break; //找到匹配 //如果找不到
int d = inf;
for(int j = 0; j < n; j++)
{
if(!vis_y[j]) d = min(d,slack[j]);
} for(int j = 0; j < n; j++) //降低期望
{
if(vis_x[j]) ex_x[j] -= d; if(vis_y[j]) ex_y[j] += d;
else slack[j] -= d;
}
}
} int res = 0;
for(int i = 0; i < n; i++)
{
res += a[match[i]][i];
}
return res;
} int main()
{
#ifdef ONLINE_JUDGE
#else
freopen("data.in", "r", stdin);
//freopen("data.out", "w", stdout);
#endif
while (~cin(n))
{
for(int i = 0; i < n; i++)
{
for(int j = 0; j < n; j++)
{
cin(a[i][j]);
}
}
printf("%d\n",km());
}
return 0;
}

例题

http://acm.hdu.edu.cn/showproblem.php?pid=2255

参考博客

https://www.cnblogs.com/wenruo/p/5264235.html

https://baike.baidu.com/item/KM算法

二分图匹配--KM算法的更多相关文章

  1. 训练指南 UVALive - 4043(二分图匹配 + KM算法)

    layout: post title: 训练指南 UVALive - 4043(二分图匹配 + KM算法) author: "luowentaoaa" catalog: true ...

  2. 牛客多校第五场 E room 二分图匹配 KM算法模板

    链接:https://www.nowcoder.com/acm/contest/143/E来源:牛客网 Nowcoder University has 4n students and n dormit ...

  3. 二分图最大权匹配——KM算法

    前言 这东西虽然我早就学过了,但是最近才发现我以前学的是假的,心中感慨万千(雾),故作此篇. 简介 带权二分图:每条边都有权值的二分图 最大权匹配:使所选边权和最大的匹配 KM算法,全称Kuhn-Mu ...

  4. 【HDU 2255】奔小康赚大钱 (最佳二分匹配KM算法)

    奔小康赚大钱 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  5. HDU 5943 Kingdom of Obsession 【二分图匹配 匈牙利算法】 (2016年中国大学生程序设计竞赛(杭州))

    Kingdom of Obsession Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Oth ...

  6. USACO 4.2 The Perfect Stall(二分图匹配匈牙利算法)

    The Perfect StallHal Burch Farmer John completed his new barn just last week, complete with all the ...

  7. HDU2255-奔小康赚大钱-二分图最大权值匹配-KM算法

    二分图最大权值匹配问题.用KM算法. 最小权值的时候把权值设置成相反数 /*-------------------------------------------------------------- ...

  8. 二分图 最大权匹配 km算法

    这个算法的本质还是不断的找增广路: KM算法的正确性基于以下定理:若由二分图中所有满足A[i]+B[j]=w[i,j]的边(i,j)构成的子图(称做相等子图)有完备匹配,那么这个完备匹配就是二分图的最 ...

  9. 二分图匹配之最佳匹配——KM算法

    今天也大致学了下KM算法,用于求二分图匹配的最佳匹配. 何为最佳?我们能用匈牙利算法对二分图进行最大匹配,但匹配的方式不唯一,如果我们假设每条边有权值,那么一定会存在一个最大权值的匹配情况,但对于KM ...

随机推荐

  1. Python 入门(1):hello world 到流程控制

    1.hello world 在D:\python\目录下新建文件hello.txt,编写代码如下 print("hello world!") 修改后缀名为.py,执行hello.p ...

  2. Keyboarding

    题目描述 思路 一开始想先写一个bfs,目标字符串要加上一个'*',表示这是一个换行符,然后一个字母一个字母的找,每次重置一下vis数组,bfs返回的结果再加上1,表示要打印这个字母,结果第一个样例没 ...

  3. golang 堆排序

    堆排序的思想  因为堆的形式是完全二叉树,跟数组的索引形成映射,可以使用数组保存.先构建最大(小)堆,根结点就是最大(小)值,删除根结点之后的节点重新构建堆,依此顺序,即可完成堆排序. 代码实现 pa ...

  4. 【LEETCODE】60、数组分类,适中级别,题目:75、560、105

    package y2019.Algorithm.array.medium; /** * @ProjectName: cutter-point * @Package: y2019.Algorithm.a ...

  5. oracle 分页sql

    select * from ( SELECT A.*, ROWNUM RN FROM ( SELECT A.*,B.USERPWiD from 测试表2 A left join 测试表3 B on A ...

  6. spring加载多个配置文件如何配置

    为应用指定多个配置文件: 多个配置文件的关系: 并列 包含 并列关系 即有多个配置文件,需要同时加载这多个配置文件: 可以使用可变参数,数组和统配符进行加载: 可变参数 String config1 ...

  7. js utc转当地时间

    javascript utc转当地时间 后台传过来的时间:2019-07-03T01:39:51.691242+08:00 转成当地时间:2019-07-02 17:39:51 new Date(20 ...

  8. 供应链管理如何提高效率?APS系统成优化引擎

    APS系统,虽然它的起兴只有短短的十几年,但是在这段时间里面,它为很多企业解决了很多人工手动.脑力不可解决的问题. 所以APS被誉为供应链优化引擎,APS常常被称为高级计划与排程,但也有称为高级计划系 ...

  9. MySQL--使用mysqldump进行数据库版本升级

    在MySQL跨版本升级时,建议使用mysqldump方式导出用户权限和用户数据,即使是小版本升级,导出过程中也应忽略系统数据库,避免系统表不兼容. 导出用户数据库脚本和用户创建脚本 ##======= ...

  10. Oracle UNDO块

    过程:开始一个事务--通过事务信息找到UNDO块头的所在的段名及数据文件号等--转储UNDO header--在事务表中对应槽位找到前镜像dba--转储数据块--找到对应记录得到bdba--转储数据块 ...