zoukankan      html  css  js  c++  java
  • 匈牙利算法(模板)

         
                                                  预处理
    二维数组 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
  • 相关阅读:
    Java程序员必知的8大排序(转载)
    Eclipse快捷键大全(转载)
    Java强引用、 软引用、 弱引用、虚引用(转)
    java数据类型二(转)
    为什么静态成员、静态方法中不能用this和super关键字(转)
    POJ 2002
    POJ 3126的教训
    POJ 3349
    POj 1105解题报告
    POJ 3278
  • 原文地址:https://www.cnblogs.com/DWVictor/p/10283026.html
Copyright © 2011-2022 走看看