hoj 2801 The Perfect Stall 二分图的最大匹配

 

/*

 

 

 

题目:

 

       每头奶牛喜欢在不同的地方产奶,每个地方只能容纳一头奶牛,问最多的产奶的地方

 

 

 

分析:

 

       在产奶地与奶牛之间建立匹配,然后用hungry算法做,比如奶牛a喜欢在q地产奶,则

 

       g[a][q] = true,建图即可

 

 

 

*/

 

#include <iostream>

 

#include <cstdio>

 

#include <cstring>

 

using namespace std;

 

#define X 202

 

int xm[X],ym[X],n,m;

 

bool g[X][X],use[X];

 

int dfs(int u)

 

{

 

       for(int v=1;v<=m;v++)

 

              if(g[u][v]&&!use[v])

 

              {

 

                     use[v] = true;

 

                     if(ym[v]==-1||dfs(ym[v]))

 

                     {

 

                            ym[v] = u;

 

                            xm[u] = v;

 

                            return true;

 

                     }

 

              }

 

              return false;

 

}

 

int hungry()

 

{

 

       memset(xm,-1,sizeof(xm));

 

       memset(ym,-1,sizeof(ym));

 

       int ret = 0;

 

       for(int u=1;u<=n;u++)

 

              if(xm[u]==-1)

 

              {

 

                     memset(use,false,sizeof(use));

 

                     if(dfs(u))

 

                            ret++;

 

              }

 

              return ret;

 

}

 

int main()

 

{

 

       freopen("sum.in","r",stdin);

 

       freopen("sum.out","w",stdout);

 

       while(cin>>n>>m)

 

       {

 

              int t,x;

 

              memset(g,false,sizeof(g));

 

              for(int i=1;i<=n;i++)

 

              {

 

                     scanf("%d",&t);

 

                     while(t--)

 

                     {

 

                            scanf("%d",&x);

 

                            g[i][x] = true;

 

                     }

 

              }

 

              printf("%d\n",hungry());

 

       }

 

       return 0;

 

}

 

posted @ 2012-04-07 16:02  yejinru  阅读(162)  评论(0编辑  收藏  举报