#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstdlib>
#include<map>
#include<queue>
#include <deque>
#include <list>
#include <ctime>
#include <stack>
#include <vector>
#include<iomanip>
#include<set>
#include <bitset>
#include <cassert>
using namespace std;
#define Maxn 128
#define mod
typedef long long ll;
typedef pair<int, int> PII;
#define FOR(i,j,n) for(int i=j;i<=n;i++)
#define DFR(i,j,k) for(int i=j;i>=k;--i)
#define lowbit(a) a&-a
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define mem(a) memset(a,0,sizeof(a))
#define eps 1e-9
#define PB push_back
#define MP make_pair
#define AA first
#define BB second
#define SZ size()
#define BG begin()
#define OP begin()
#define ED end()
#define SQ(x) ((x)*(x))
const int inf = 0x7f7f7f7f;
const double pi = acos(-1.0);
int t,x,y;
int e[Maxn][Maxn];
int match[Maxn];
int book[Maxn];
int DFS(int u)
{ FOR(i,1,x)
{ if(!book[i] && e[u][i])
{ book[i]=1;
if(! match[i] || DFS(match[i]))
{
match[i]=u;
return 1;
}
}
}
return 0;
}
int main()
{ cin>>t;
while(t--)
{ cin>>x>>y;
mem(e);mem(match);
FOR(i,1,y)
{int a,b;cin>>a>>b;e[a][b]=1;}
int sum=0;
FOR(i,1,x)
{ mem(book);
if(DFS(i))sum++;
}
cout<<x-sum<<endl;
}
return 0;
}
hdu 1151 匈牙利算法
最新推荐文章于 2022-08-23 21:36:13 发布