匈牙利算法--java
先上例题
杭电acm 2063 :http://acm.hdu.edu.cn/showproblem.php?pid=2063
bool 寻找从k出发的对应项出的可增广路 {
while (从邻接表中列举k能关联到顶点j)
{
if (j不在增广路上)
{
把j加入增广路;
if (j是未盖点 或者 从j的对应项出发有可增广路)
{
修改j的对应项为k;
则从k的对应项出有可增广路,返回true;
}
}
}
则从k的对应项出没有可增广路,返回false;
}
void 匈牙利hungary()
{
for i->1 to n
{
if (则从i的对应项出有可增广路)
匹配数++;
}
输出 匹配数;
}
附上题解代码
import java.util.*; public class Main { public int map[][]=new int [1010][1010];//男生和女的有关系数
public int match[]=new int[1010]; //是否已经匹配数
public int used[]=new int [1010]; //是否有关系
public boolean find(int x,int n ){
for(int i=1;i<=n;i++){
if(used[i]==0&&map[x][i]==1){ //如果没有i男生是空闲的且x,i有关系 used[i]=1;
if(match[i]==-1||find(match[i],n)){ //如果i男生没有匹配或者她放弃男生i并且另外找到了自己的伴
match[i]=x;
return true;
}
} }return false;
} //该函数判断女生爱能不能找到伴 public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int k,m,n;
while(sc.hasNext()){
k=sc.nextInt();
if(k==0)
System.exit(0);
m=sc.nextInt();
n=sc.nextInt();
int cnt=0;
Main lei=new Main();
Arrays.fill(lei.match,-1);
for(int i=0;i<lei.map.length;i++){
for(int j=0;j<lei.map.length;j++){
lei.map[i][j]=0;
}
}
for(int i=1;i<=k;i++){
int a,b;
a=sc.nextInt();
b=sc.nextInt();
lei.map[a][b]=1;
}
for(int i=1;i<=m;i++){
Arrays.fill(lei.used,0);
if(lei.find(i,n))
cnt++;
}
System.out.println(cnt);
}
}
}
匈牙利算法精髓就是尽可能的多占,可以通过回溯来试,不过当试的时候破坏了之前的安排,则是无能为力的,只能要求尽可能的多。
杭电3020
package demo2; import java.util.*; public class Main6 {
static int edge[][]=new int [1005][1005]; static int num_map[][]=new int [1000][1001];
static char map[][]=new char[1000][1001];
static int cx[]=new int[505];
static int cy[]=new int[505];
static int vis[]=new int[505];
static int match[]=new int[505];
static int N,K,M;
static int d[][]={{-1,0},{1,0},{0,-1},{0,1}};
public static int path(int u){
int v;
for(v=1;v<=M;v++){
if(vis[v]==0&&edge[u][v]==1){
vis[v]=1;
if(match[v]==-1||path(match[v])==1){
match[v]=u;
return 1;
}
}
}
return 0;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
N = sc.nextInt(); while(N-->0){
int count=0;
for(int i=0;i<num_map.length;i++)
Arrays.fill(num_map[i], 0);
for(int i=0;i<edge.length;i++)
Arrays.fill(edge[i], 0); int m= sc.nextInt();
int k = sc.nextInt();
sc.nextLine();
for(int i=0;i<m;i++){
String s = sc.nextLine();
map[i]=s.toCharArray(); } // int res=0;
int num=0;
for(int i=0;i<m;i++){
for(int j=0;j<k;j++){
// System.out.print([i][j]);
if(map[i][j]=='*'){
num_map[i][j]=++num; // System.out.println(num_map[i][j]);
}
}
// System.out.println();
}
K=num;M=num;
System.out.println(num);
for(int i=0;i<m;i++){
for(int j=0;j<k;j++){
if(num_map[i][j]!=0){
// System.out.println(num_map[i][j]);
for(int c=0;c<4;c++){
int x = i+d[c][0];
int y = j+d[c][1];
if(x<0||y<0||x>=m||y>=k)
continue;
if(num_map[x][y]!=0)
edge[num_map[i][j]][num_map[x][y]]=1; }
}
}
}
// for(int i=1;i<=m;i++){
// for(int j=1;j<=k;j++){
// System.out.print(num_map[i][j]);
// }
// System.out.println();
// }
Arrays.fill(match, -1);
for(int i=1;i<=K;i++){
Arrays.fill(vis, 0);
if(path(i)==1)
count++;
}
System.out.println(num-count/2);
}
}
}
匈牙利算法--java的更多相关文章
- HDU 5943 Kingdom of Obsession 【二分图匹配 匈牙利算法】 (2016年中国大学生程序设计竞赛(杭州))
Kingdom of Obsession Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Oth ...
- hdoj 1083 Courses【匈牙利算法】
Courses Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total S ...
- hdoj 2063 过山车【匈牙利算法+邻接矩阵or邻接表】
过山车 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- [ACM] HDU 2063 过山车 (二分图,匈牙利算法)
过山车 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- HDU--3081--Marriage Match II--最大匹配,匈牙利算法
Marriage Match II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- HDU2063-过山车-匈牙利算法
过山车 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- HDU 2444 - The Accomodation of Students - [二分图判断][匈牙利算法模板]
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=2444 Time Limit: 5000/1000 MS (Java/Others) Mem ...
- HDU 1045 - Fire Net - [DFS][二分图最大匹配][匈牙利算法模板][最大流求二分图最大匹配]
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1045 Time Limit: 2000/1000 MS (Java/Others) Mem ...
- hdu 1013 过山车 匈牙利算法(代码+详细注释)
过山车 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
随机推荐
- 使用docker方式安装etcd集群,带TLS证书
网上文档也多,安装的时候,还是踩了几个坑. 现在作一个安装记录吧. 1,先作自签名的证书ca-csr.json(为了和k8s共用根证书,可能将信息调为k8s). { "CN": & ...
- 使用shell脚本定时采集日志数据到hdfs分布式文件系统
1.首先对linux操作系统的crontab命令进行熟悉和了解: .crond是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系 ...
- 【bzoj4811】[Ynoi2017]由乃的OJ 树链剖分+线段树区间合并
题解: 好像和noi那题并没有什么区别 只是加上了修改和变成树上 比较显然我们可以用树链剖分来维护
- [转]git 删除远程仓库文件
来源:https://www.jianshu.com/p/de75a9e3d1e1 git删除远程文件夹或文件的方法 项目开发初期由于.gitignore 文件配置不正确很有可能导致某些不需要的目录上 ...
- Linux批量清空当前目录中的日志文件
在Linux中,有时需要批量清空当前目录中的日志文件,同时还要保留日志文件. 其实一行shell命令就可以搞定,一起来看看吧. 在当前目录下,键入如下命令: for i in `find . -nam ...
- keepalived + glusterfs实现高可用
此处暂时不介绍原理乱七八糟,边做别记录下操作. 1.服务器修改网卡的名字为eth0 .将device和name都改成eth0 vim /etc/sysconfig/network-scripts/if ...
- windows安装Python虚拟环境
1.pip install virtualenv 安装virtualenv镜像 3.virtualenv scrapytest 新建virtualenv 4.cd到\scrapytest\Scrip ...
- day15 函数的使用方法:递归函数
这里归纳的知识点主要就是: 浮点数,复数, int,整形:float,浮点数:complx,复数: # 实数: # 有理数 有限小数 1.2 # 无限循环小数 1.23232323232323.... ...
- python之psutil模块(获取系统性能信息(CPU,内存,磁盘,网络)
一.psutil模块 1. psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网络等) ...
- 从零搭建 ES 搜索服务(六)相关性排序优化
一.前言 上篇介绍了搜索结果高亮的实现方法,本篇主要介绍搜索结果相关性排序优化. 二.相关概念 2.1 排序 默认情况下,返回结果是按照「相关性」进行排序的--最相关的文档排在最前. 2.1.1 相关 ...