匈牙利算法(模板)

 

     
                                              预处理
二维数组 map[N][N];用来记录两点是否可以链接
一维数组 link[N];用来记录有哪个点占用了哪个点
一维数组 ok[N];判断点是否被用过
bool dfs(int a)
{
  for(int i=0;i<N;i++)遍历后数组寻找有是否可以相连的
  {
    如果 没有相连并且没有被用过
    那么 标记被用过并且进行下一步操作
        判断一下这个点被占用 
如果没有被占用 则记录这个点被a占用 返回真 表示a点找到对应点了
否则 重新调用一下dfs(link[i]) 如果返回值为真表示
在这个点被a占用后 之前占用这个点的点可以找到新的点去匹配
之后再返回真
  }
  如果遍历所有没有找到对应点那么就是表示没有找到匹配点 返回假
}
dfs返回值代表 寻找的是一个点在之前的点有匹配的情况下 该点是否可以找到一个匹配点
记录最多匹配时应用一个循环去记录
int ans=0;
for(int i=0;i<N;i++)
  {
    memset(ok,0,sizeof(ok));进行调用一次dfs时必要的预处理
    if(dfs(i))
      ans++;
  }
答案即为ans

转载于:https://www.cnblogs.com/DWVictor/p/10283026.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值