【二分图匹配】最大匹配-匈牙利算法BFS && DFS写法

这篇博客详细介绍了如何使用匈牙利算法解决二分图的最大匹配问题,包括BFS和DFS两种写法。在BFS实现中,需要额外的Prev数组记录路径,而DFS则利用栈隐式存储。文章通过实例解释了不同情况下的数组初始化,并提供了HDU2444问题作为示例,展示了算法的应用,最终输出最多能分配的牛栏数量。
摘要由CSDN通过智能技术生成

搞了两节课终于搞懂了ORZ

这个讲解得很详细http://blog.csdn.net/pi9nc/article/details/11848327  

注意:每次找增广路之前都要初始化

           BFS写法要多加一个Prev数组保存这个点从哪个点来(同侧)

          如果给出的两个点集各自序号都是1~n的: 对于DFS写法 因为其隐形地调用了一个栈 只要开一个Matchine数组记录一侧的匹配;

                                                                                      对于BFS写法  必须开两个Matchine数组

          如果给出的点集只有一组序号= =就只要开一个了233  如果两个集合序号互有穿插,可以都下去找一遍,匹配数/2 

         比如下面HDU2444

#include<cstdio>
#include<cstring>
using namespace std;
#define maxn 210
bool flag;
int i,n,m,color[maxn],map[maxn][maxn],matchine[maxn],mark[maxn],ans;

void dfs(int now,int x){
     for (int i=1;i<=n;i++){
         if (map[now][i]){
            if (!color[i]) {
               color[i]=3-x;
               dfs(i,3-x);
               }
               else if (color[i]==x) {
                    flag=false;
                    return;
                    }
               if (flag==false) return;
            }
     }
}
           
bool check(){
     memset(color,0,sizeof(color));
     color[1]=1;
     flag=true;
     dfs(1,1);
     return flag;
}
     
bool find(int now){  
     for (int j=1;j<=n;j++)
       if (map[now][j] && !mark[j]){
           m
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值