匈牙利算法--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 ...
随机推荐
- Redis的并发竞争问题
问题描述:多客户端同时并发写一个key,可能本来应该先到的数据后到了,导致数据版本错了.或者是多客户端同时获取一个key,修改值之后再写回去,只要顺序错了,数据就错了. 一个key的值是1,本来按顺序 ...
- 标准I/O的缓冲
标准I/O实现了三种类型的用户缓冲,并为开发者提供了接口,可以控制缓冲区类型和大小. 无缓冲(Unbuffered) 不执行用户缓冲.数据直接提交给内核.因为这种无缓冲模式不支持用户缓冲(用户缓冲一般 ...
- C# 之 GUID格式化
Guid的带参数的ToString()方法来实现格式化,如下: //// 摘要: // 根据所提供的格式说明符,返回此 System.Guid 实例值的字符串表示形式. //// 参数: // ...
- HTML LIST 输入框自动查询追加框,自动过滤 HTML5
<!DOCTYPE HTML> <html> <body> <form action="/example/html5/demo_form.asp&q ...
- cmake与autoconf+automake
cmake与autoconf+automakes是同类的编译工具,本人常用的是cmake. 这有一篇对比的文章,记录一下. cmake与autoconf+automake的对比
- JMeter高并发场景下存在请求无数据
- 关于java中的伪共享的认识和解决
在并发编程过程中,我们大部分的焦点都放在如何控制共享变量的访问控制上(代码层面),但是很少人会关注系统硬件及 JVM 底层相关的影响因素: CPU缓存 网页浏览器为了加快速度,会在本机存缓存以前浏览过 ...
- seafile数据的备份与恢复
seafile数据备份包括MySQL数据备份与seafile,seahub数据备份两个部分.所以在备份的时候需要注意这一点. 我的存储底层用glusterfs数据共享,为了防止一台服务器宕机以后另一台 ...
- 关闭PHP的opcache缓存
1.使用phpinfo();查看配置信息 2.搜索Additional .ini files parsed 3.查看opcache安装目录 4.打开文件将 opcache.enable=1 改成 ...
- oracle的存储过程和定时任务编写体会
create or replace procedure clear_product is p_sql char(200) p_r_sql char(200) begin p_sql := ''; p_ ...