HDU 2853 最大匹配&KM模板
http://acm.hdu.edu.cn/showproblem.php?pid=2853
这道题初看了没有思路,一直想的用网络流如何解决
参考了潘大神牌题解才懂的
最大匹配问题KM
还需要一些技巧来解决最小变动,
做法是:把原先的邻接矩阵每个数扩大k倍(k>n)
为了突出原先的选择,也就是同等情况下优先选择原来的方案
给原来的方案对应矩阵内的数据+1
那么
最终得出的最大匹配值/k=真实的最大匹配
最终得出的最大匹配值%k=原来的方案采用了几个
这里的KM留下来做模板
/*
二分图最佳匹配 (kuhn munkras 算法 O(m*m*n)).
邻接矩阵形式 。 返回最佳匹配值,传入二分图大小m,n
邻接矩阵 mat ,表示权,match1,match2返回一个最佳匹配,为匹配顶点的match值为-1,
一定注意m<=n,否则循环无法终止,最小权匹配可将全职取相反数。
初始化: for(i=0;i<MAXN;i++)
for(j=0;j<MAXN;j++) mat[i][j]=-inf;
对于存在的边:mat[i][j]=val;//注意不能负值
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 55
#define inf 1000000000
#define _clr(x) memset(x,-1,sizeof(int)*maxn)
using namespace std;
int donser[maxn][maxn];
int match1[maxn],match2[maxn];
int km(int m,int n,int mat[][maxn],int *match1,int *match2)
{
int s[maxn],t[maxn],ak[maxn],ac[maxn];
int p,q,i,j,k,ret=;
for(i=;i<m;i++)
{
ak[i]=-inf;
for(j=;j<n;j++)
ak[i]=mat[i][j]>ak[i]?mat[i][j]:ak[i];
if(ak[i]==-inf) return -;
}
for(i=;i<n;i++)
ac[i]=;
_clr(match1);
_clr(match2);
for(i=;i<m;i++)
{
_clr(t);
p=;q=;
for(s[]=i;p<=q&&match1[i]<;p++)
{
for(k=s[p],j=;j<n&&match1[i]<;j++)
{
if(ak[k]+ac[j]==mat[k][j]&&t[j]<)
{
s[++q]=match2[j];
t[j]=k;
if(s[q]<)
{
for(p=j;p>=;j=p)
{
match2[j]=k=t[j];
p=match1[k];
match1[k]=j;
}
}
}
}
}
if(match1[i]<)
{
i--;
p=inf;
for(k=;k<=q;k++)
{
for(j=;j<n;j++)
{
if(t[j]<&&ak[s[k]]+ac[j]-mat[s[k]][j]<p)
p=ak[s[k]]+ac[j]-mat[s[k]][j];
}
}
for(j=;j<n;j++)
ac[j]+=t[j]<?:p;
for(k=;k<=q;k++)
ak[s[k]]-=p;
}
}
for(i=;i<m;i++)
ret+=mat[i][match1[i]];
return ret;
}
int main()
{
int n,m,i,j;
while(~scanf("%d%d",&n,&m))
{
int k=n+,t,num=;
for(i=;i<n;i++)
{
for(j=;j<m;j++)
{
scanf("%d",&t);
donser[i][j]=t*k;
}
}
for(i=;i<n;i++)
{
scanf("%d",&t);
//cout<<i<<" "<<t-1<<" "<<donser[i][t-1]<<endl;
num+=donser[i][t-]/k;
donser[i][t-]+=;
}
int kk=km(n,m,donser,match1,match2);
cout<<n-kk%k<<" "<<kk/k-num<<endl;
memset(donser,,sizeof(donser));
}
return ;
}
HDU 2853 最大匹配&KM模板的更多相关文章
- HDU 2853 & 剩余系+KM模板
题意: 给你一张二分图,给一个原匹配,求原匹配改动最少的边数使其边权和最大. SOL: 我觉得我的智商还是去搞搞文化课吧..这种题给我独立做我大概只能在暴力优化上下功夫.. 这题的处理方法让我想到了剩 ...
- 【HDU 2853】 KM算法
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2853 题意:有n个公司,m个任务,每个公司做每个任务都有一个效率值,最开始每个公司都指派了一个任务,现 ...
- hdu 2853 Assignment KM算法
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2853 Last year a terrible earthquake attacked Sichuan ...
- HDU 2853 Assignment(KM最大匹配好题)
HDU 2853 Assignment 题目链接 题意:如今有N个部队和M个任务(M>=N),每一个部队完毕每一个任务有一点的效率,效率越高越好.可是部队已经安排了一定的计划,这时须要我们尽量用 ...
- 【HDU 2853】Assignment (KM)
Assignment Problem Description Last year a terrible earthquake attacked Sichuan province. About 300, ...
- Assignment HDU - 2853(二分图匹配 KM 新边旧边)
传送门: Assignment HDU - 2853 题意:题意直接那松神的题意了.给了你n个公司和m个任务,然后给你了每个公司处理每个任务的效率.然后他已经给你了每个公司的分配方案,让你求出最多能增 ...
- 带权二分图最大匹配KM算法
二分图的判定 如果一个图是连通的,可以用如下的染色法判定是否二分图: 我们把X部的结点颜色设为0,Y部的颜色设为1. 从某个未染色的结点u开始,做BFS或者DFS .把u染为0,枚举u的儿子v.如果v ...
- HDU 2853 (KM最大匹配)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2853 题目大意:二分图匹配费用流.①最大匹配②最小原配变动 解题思路: 如果去掉第二个要求,那么就是裸 ...
- HDU 2255 & KM模板
题意: 一张完备二分图求最优完备匹配. SOL: 这题就不讲什么sol了...毕竟是裸的KM,不会的话可以看老人家的大白鼠,一些问题看代码注释.讲讲经历(悲惨的经历) 刚打完,自信地交上去发现MLE. ...
随机推荐
- mysql 字符串
mysql中一个字符串,既可以用两个单引号表示,也可以用两个双引号表示. 比如字符串 wangxiaowei,用单引号表示 'wangxiaowei',双引号表示"wangxiaowei&q ...
- scrapy2_初窥Scrapy
递归知识:oop,xpath,jsp,items,pipline等专业网络知识,初级水平并不是很scrapy,可以从简单模块自己写. 初窥Scrapy Scrapy是一个为了爬取网站数据,提取结构性数 ...
- java实现Haffman编码
1.先创建一个树节点类(泛型类),为了方便使用集合的排序方法,泛型类要实现泛型接口Comparable,代码如下 package com.hjp.huffman; /** * Created by J ...
- ubuntu下安装TexLive和Texmaker
也可以参考ubuntu14.04配置中文latex完美环境(texlive+texmaker+lyx) 设置中文字体的时候参考ubuntu 下安装 texlive 并设置 ctex 中文套装 1.首先 ...
- Mac技巧
////////////////////////////////////////////////////////////////////////////////PC键盘在Mac上的映射Ctrl = C ...
- Ubuntu terminal 不见了
Python出问题了,卸载Python后,terminal竟然消失了.. Ctrl + Alt + T出现的是XTerm 解决办法: 在XTerm中输入命令: # sudo apt-get insta ...
- xhprof安装使用
安装: 到pecl官网下载xhprof的最新版:http://pecl.php.net/package/xhprof wget http://pecl.php.net/get/xhprof-0.9.4 ...
- jsp机制基础
JSP 和Servlet技术一样,JSP也是SUN公司定义的一种开发动态web资源的技术,属于JavaEE技术之一.JSP实际上就是Servlet,它们在一起又称JSP/Servlet规范. Serv ...
- XMLBEANS的使用总结
在本文中,我们将详细了解最好的数据对象XMLBean.从传统角度来说,在Java应用程序中使用XML,就是在从 XML文档向Java导入数据的技术或从数据模型层向XML导出数据技术之间架起了一座桥梁. ...
- Mono资源
摘要 最近看了一部分mono方面的资料,这里整理一下,在这里列一个目录,方便以后用到的时候查找. Mono Mono 是一个由 Xamarin 公司(先前是 Novell,最早为 Ximian)所主持 ...