匈牙利算法--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 ...
随机推荐
- CAS5.3.X 配置备忘
## # 普通MD5用户jdbc验证 ## #配置数据库连接 cas.authn.jdbc.query[0].driverClass=com.mysql.cj.jdbc.Driver cas.auth ...
- 使用Github Pages和Hexo构建个人博客
Github Pages可以创建免费的静态站点,支持自带主题.支持自制页面等,并且可以使用Jekyll或者Hexo等静态博客框架进行管理. 独立博客是博客园等博客平台之外的一个良好补充,相比使用虚拟主 ...
- 【SpringBoot】常用注解
@EnableAutoConfiguration 启动自动装载:使用了这个注解之后,所有引入的jar的starters都会被自动注入.这个类的设计就是为starter工作的. @RestControl ...
- 构建简单的json树形菜单
json结构: var Menu = [{ tit:"一级菜单", submenu:[{ tit:"二级菜单", url:"", func: ...
- fillder---安装证书(抓取https)
1.fillder中设置如下(不用管为啥,按照这个设置就对了) 2.需要在手机上安装证书,有两种方式 方式一:fillder直接导出到手机中 方式二:手机上直接下载 打开手机自带浏览器:网址输入[XX ...
- 数位dp 模板
不能有49 #include<bits/stdc++.h> using namespace std; //input by bxd #define rep(i,a,b) for(int i ...
- LeetCode 234. 回文链表
class Solution { public: bool isPalindrome(ListNode* head) { deque<int> d1, d2; ListNode* p = ...
- busybox linux-2.6.2 编译安装中碰到的若干问题
Q1 /busybox-1.18.4/scripts/gcc-version.sh: line 11: arm-linux-gcc: command not found 1.问题:/home/ub ...
- fastAdmin进阶
基本知识流程一栏链接 bootstrapTable fastadmin系统配置(符内置规则): fastadmin默认的controller已实现的方法 一张图解析fastadmin的表格: fast ...
- HDU 3829 Cat VS Dog (最大独立集)【二分图匹配】
<题目链接> 题目大意: 动物园有n条狗.m头猫.p个小孩,每一个小孩有一个喜欢的动物和讨厌的动物.如今动物园要转移一些动物.假设一个小孩喜欢的动物在,不喜欢的动物不在,他就会happy. ...