二分图最小顶点覆盖 hdu1150

http://acm.hdu.edu.cn/showproblem.php?pid=1150

在二分图中求最少的点,让每条边都至少和其中的一个点关联,这就是“二分图的最小顶点覆盖”。
最小顶点覆盖=最大匹配数

#include 
#include 
#include 
using namespace std;

const int MAXN=105;
int m1,m2;
int g[MAXN][MAXN];
int used[MAXN];
int linker[MAXN];

int dfs(int u)
{
    for(int v=1;vif(g[u][v]&&!used[v])
        {used[v]=1;
            if(linker[v]==-1||dfs(linker[v]))
            {
                linker[v]=u;
                return true;
            }
        }
    }
    return false;
}

int hungary(int m1)
{
    int res=0;
    memset(linker,-1,sizeof(linker));
    for(int u=1;umemset(used,0,sizeof(used));
        if(dfs(u))res++;
    }
    return res;
}

int main()
{int num;
 while(cin>>m1)
 {memset(g,0,sizeof(g));
     if(m1==0)break;
     cin>>m2>>num;
     for(int i=0;iint v1,v2,n;
         cin>>n>>v1>>v2;
         g[v1][v2]=1;
     }
     cout<return 0;
}

你可能感兴趣的:(图论)