hdu 3289 最大独立集

时间:2023-03-09 03:52:35
hdu 3289  最大独立集

题意:一个动物园里有N只猫和K只狗,一些小朋友来参观,他们如果喜欢狗就不喜欢猫,喜欢猫就不喜欢狗,园长想要移走一些动物,如果,移走的是某个小朋友不喜欢的,而喜欢的没被移走,该小朋友就会高兴,求移动的数目使得最多的小朋友开心

Sample Input
1 1 2   //1个猫1个狗2个小朋友
C1 D1   //一号小朋友喜欢c1,讨厌d1
D1 C1
1 2 4
C1 D1
C1 D1
C1 D2
D2 C1
转换为最大独立集做
 #include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
using namespace std;
#define for0n for(i=0;i<n;i++)
#define for1n for(i=1;i<=n;i++)
#define cl(a) memset(a,0,sizeof(a))
#define w12 while(scanf("%d%d",&n,&m)!=EOF)
int n,m,t;
const int MAXN = ;
int uN,vN;//u,v的数目,使用前面必须赋值
int g[MAXN][MAXN];//邻接矩阵
int linker[MAXN];
bool used[MAXN];
bool dfs(int u)
{
for(int v = ; v < vN;v++)
if(g[u][v] && !used[v])
{
used[v] = true;
if(linker[v] == - || dfs(linker[v]))
{
linker[v] = u;
return true;
}
}
return false;
}
int hungary()
{
int res = ;
memset(linker,-,sizeof(linker));
for(int u = ;u < uN;u++)
{
memset(used,false,sizeof(used));
if(dfs(u))res++;
}
return res;
}
int main()
{
int i,j,k;
#ifndef ONLINE_JUDGE
freopen("1.in","r",stdin);
#endif
char s1[MAXN][],s2[MAXN][];
int p;
while(scanf("%d%d%d",&n,&m,&p)!=EOF)
{
cl(g);
for(i=;i<p;i++)
{
scanf("%s%s",s1[i],s2[i]);
}
uN=vN=p;
for(i=;i<p;i++)
{
for(j=i+;j<p;j++)
{
if(strcmp(s1[i],s2[j])==||strcmp(s1[j],s2[i])==)
{
g[i][j]=;
g[j][i]=;
}
}
}
printf("%d\n",p-hungary()/);
}
}