题意:给出一些同学彼此了解,然后求要选出一些同学,两两之间都了解的最大数量。
思路:其实也是个最大独立集问题,就是不了解才建边,求出的最大独立集也就是任意两两之间都是了解的。
#include<iostream>
using namespace std;
bool g[205][205];
bool vis[205];
int G,B;
int link[205];
bool dfs(int u)
{
for(int i=1;i<=B;i++)
{
if(!vis[i]&&g[u][i])
{
vis[i]=1;
if(link[i]==-1||dfs(link[i]))
{
link[i]=u;
return true;
}
}
}
return false;
}
int maxmatch()
{
int num=0;
memset(link,-1,sizeof(link));
for(int i=1;i<=G;i++)
{
memset(vis,0,sizeof(vis));
if(dfs(i)) num++;
}
return num;
}
int main()
{
int M;
int a,b;
int h=1;
while(scanf("%d%d%d",&G,&B,&M)!=EOF)
{
if(G==0&&B==0&&M==0) break;
for(int i=1;i<=G;i++)
for(int j=1;j<=B;j++)
g[i][j]=1;
while(M--)
{
scanf("%d%d",&a,&b);
g[a][b]=0;
}
printf("Case %d: %d\n",h++,G+B-maxmatch());
}
}