博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
匈牙利算法(模板)
阅读量:5322 次
发布时间:2019-06-14

本文共 533 字,大约阅读时间需要 1 分钟。

 

     
                                              预处理
二维数组 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

你可能感兴趣的文章
添加Centos最新yum源
查看>>
列表和表格
查看>>
书单 (长期更新)
查看>>
css -- 映像 ,分页(上一页下一页)
查看>>
Eclipse超级完美汉化教程
查看>>
CAS 之 集成RESTful API
查看>>
Ajax异步网络请求及JSONP跨域
查看>>
[JSOI2007]字符加密
查看>>
ES6--Module的语法
查看>>
Android Widget点击事件
查看>>
用PS绿化版出现“请卸载并重新安装该产品”的解决方法
查看>>
[从产品角度学EXCEL 00]-为什么要关注EXCEL的本质
查看>>
相关 Java 视频教程 网址
查看>>
CS231n assignment1 Q2 SVM
查看>>
数据契约(DataContract)里的DataMember特性
查看>>
Java list对象列表排序 实例
查看>>
迭代器
查看>>
MySQL数据中分级分组显示数据
查看>>
Android--清除默认桌面设置和设置默认桌面(转)
查看>>
Android--px(像素)和dp、sp之间的相互转化
查看>>